From a626887c7ba27423e233b80aa394138946242d5d Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 14:37:47 +0100 Subject: [PATCH 01/17] Fix #262: Moved from Newtonsoft.Json to System.Text.Json --- CDP4-SDK.sln | 6 + CDP4-SDK.sln.DotSettings | 2 +- CDP4Dal.NetCore.Tests/DAL/DalTestFixture.cs | 38 +- .../OperationContainerTestFixture.cs | 38 +- .../Operations/OperationTestFixture.cs | 30 +- .../Operations/PostOperationTestFixture.cs | 40 +- .../Operations/ThingTransactionTestFixture.cs | 39 +- CDP4Dal.NetCore.Tests/SessionTestFixture.cs | 129 +- CDP4Dal.Tests/DAL/DalTestFixture.cs | 61 +- .../OperationContainerTestFixture.cs | 38 +- .../Operations/OperationTestFixture.cs | 30 +- .../Operations/PostOperationTestFixture.cs | 40 +- .../Operations/ThingTransactionTestFixture.cs | 84 +- CDP4Dal.Tests/SessionTestFixture.cs | 107 +- CDP4Dal/DAL/Dal.cs | 39 +- CDP4Dal/DAL/IDal.cs | 35 +- .../InvalidOperationContainerException.cs | 22 +- .../InvalidOperationKindException.cs | 24 +- CDP4Dal/ISession.cs | 22 +- CDP4Dal/Operations/IThingTransaction.cs | 29 +- CDP4Dal/Operations/LongRunningTaskResult.cs | 4 +- CDP4Dal/Operations/OperationContainer.cs | 37 +- CDP4Dal/Operations/OperationKindExtensions.cs | 26 +- CDP4Dal/Operations/ThingTransaction.cs | 135 +- CDP4Dal/Session.cs | 23 +- .../Protocol}/Operations/Operation.cs | 136 +- .../Protocol}/Operations/OperationKind.cs | 180 +- .../Protocol}/Operations/PostOperation.cs | 157 +- .../{ => Protocol}/Tasks/CometTask.cs | 10 +- .../{ => Protocol}/Tasks/StatusKind.cs | 25 +- .../CDP4DalJsonSerializer.csproj | 44 + .../Cdp4DalJsonSerializer.cs | 86 + .../Extensions/JsonElementExtensions.cs | 70 + .../PostOperationJsonConverter.cs | 150 ++ .../JsonFileDalTestFixture.cs | 19 +- .../JsonFileDalTestFixture.cs | 27 +- CDP4JsonFileDal/CDP4JsonFileDal.csproj | 1 + CDP4JsonFileDal/JsonFileDal.cs | 39 +- .../Helper/SerializerHelperTestFixture.cs | 46 +- .../JsonSerializerTestFixture.cs | 29 +- .../Helper/SerializerHelperTestFixture.cs | 48 +- .../JsonSerializerTestFixture.cs | 34 +- .../PostOperation/CdpPostOperation.cs | 29 +- .../ActionItemResolver.cs | 292 ++- .../ActualFiniteStateListResolver.cs | 132 +- .../ActualFiniteStateResolver.cs | 121 +- .../AutoGenDtoDeserializer/AliasResolver.cs | 136 +- .../AndExpressionResolver.cs | 110 +- .../ApprovalResolver.cs | 169 +- .../ArrayParameterTypeResolver.cs | 205 ++- .../BinaryNoteResolver.cs | 176 +- .../BinaryRelationshipResolver.cs | 161 +- .../BinaryRelationshipRuleResolver.cs | 216 ++- .../AutoGenDtoDeserializer/BookResolver.cs | 158 +- .../BooleanParameterTypeResolver.cs | 175 +- .../AutoGenDtoDeserializer/BoundsResolver.cs | 158 +- .../BuiltInRuleVerificationResolver.cs | 148 +- .../CategoryResolver.cs | 182 +- .../ChangeProposalResolver.cs | 259 ++- .../ChangeRequestResolver.cs | 248 ++- .../CitationResolver.cs | 158 +- .../AutoGenDtoDeserializer/ColorResolver.cs | 147 +- .../CommonFileStoreResolver.cs | 150 +- .../CompoundParameterTypeResolver.cs | 190 +- .../ConstantResolver.cs | 191 +- .../ContractChangeNoticeResolver.cs | 259 ++- .../CyclicRatioScaleResolver.cs | 270 ++- .../DateParameterTypeResolver.cs | 175 +- .../DateTimeParameterTypeResolver.cs | 175 +- .../DecompositionRuleResolver.cs | 197 +- .../DefinitionResolver.cs | 140 +- ...ependentParameterTypeAssignmentResolver.cs | 125 +- .../DerivedQuantityKindResolver.cs | 208 ++- .../DerivedUnitResolver.cs | 161 +- .../DiagramCanvasResolver.cs | 139 +- .../DiagramEdgeResolver.cs | 183 +- .../DiagramObjectResolver.cs | 179 +- .../DomainFileStoreResolver.cs | 161 +- .../DomainOfExpertiseGroupResolver.cs | 164 +- .../DomainOfExpertiseResolver.cs | 164 +- .../AutoGenDtoDeserializer/DtoFactory.cs | 34 +- .../ElementDefinitionResolver.cs | 199 +- .../ElementUsageResolver.cs | 200 +- .../EmailAddressResolver.cs | 125 +- ...ineeringModelDataDiscussionItemResolver.cs | 158 +- .../EngineeringModelDataNoteResolver.cs | 172 +- .../EngineeringModelResolver.cs | 164 +- .../EngineeringModelSetupResolver.cs | 236 ++- .../EnumerationParameterTypeResolver.cs | 190 +- .../EnumerationValueDefinitionResolver.cs | 146 +- .../ExclusiveOrExpressionResolver.cs | 110 +- .../ExternalIdentifierMapResolver.cs | 176 +- .../AutoGenDtoDeserializer/FileResolver.cs | 139 +- .../FileRevisionResolver.cs | 162 +- .../FileTypeResolver.cs | 175 +- .../AutoGenDtoDeserializer/FolderResolver.cs | 158 +- .../GlossaryResolver.cs | 171 +- .../AutoGenDtoDeserializer/GoalResolver.cs | 153 +- .../HyperLinkResolver.cs | 136 +- .../IdCorrespondenceResolver.cs | 125 +- ...ependentParameterTypeAssignmentResolver.cs | 125 +- .../IntervalScaleResolver.cs | 259 ++- .../IterationResolver.cs | 263 ++- .../IterationSetupResolver.cs | 180 +- .../LinearConversionUnitResolver.cs | 179 +- .../LogEntryChangelogItemResolver.cs | 143 +- .../LogarithmicScaleResolver.cs | 310 +++- .../MappingToReferenceScaleResolver.cs | 125 +- .../ModelLogEntryResolver.cs | 186 +- .../ModelReferenceDataLibraryResolver.cs | 238 ++- .../ModellingThingReferenceResolver.cs | 125 +- .../MultiRelationshipResolver.cs | 146 +- .../MultiRelationshipRuleResolver.cs | 197 +- .../NaturalLanguageResolver.cs | 136 +- .../NestedElementResolver.cs | 136 +- .../NestedParameterResolver.cs | 169 +- .../NotExpressionResolver.cs | 114 +- .../AutoGenDtoDeserializer/OptionResolver.cs | 160 +- .../OrExpressionResolver.cs | 110 +- .../OrdinalScaleResolver.cs | 270 ++- .../OrganizationResolver.cs | 136 +- .../OrganizationalParticipantResolver.cs | 114 +- .../OwnedStyleResolver.cs | 253 ++- .../AutoGenDtoDeserializer/PageResolver.cs | 158 +- .../ParameterGroupResolver.cs | 125 +- .../ParameterOverrideResolver.cs | 139 +- .../ParameterOverrideValueSetResolver.cs | 149 +- .../ParameterResolver.cs | 216 ++- .../ParameterSubscriptionResolver.cs | 121 +- .../ParameterSubscriptionValueSetResolver.cs | 130 +- .../ParameterTypeComponentResolver.cs | 136 +- .../ParameterValueSetResolver.cs | 161 +- .../ParameterizedCategoryRuleResolver.cs | 175 +- .../ParametricConstraintResolver.cs | 121 +- .../ParticipantPermissionResolver.cs | 136 +- .../ParticipantResolver.cs | 154 +- .../ParticipantRoleResolver.cs | 164 +- .../PersonPermissionResolver.cs | 136 +- .../AutoGenDtoDeserializer/PersonResolver.cs | 256 ++- .../PersonRoleResolver.cs | 164 +- .../AutoGenDtoDeserializer/PointResolver.cs | 136 +- .../PossibleFiniteStateListResolver.cs | 179 +- .../PossibleFiniteStateResolver.cs | 146 +- .../PrefixedUnitResolver.cs | 157 +- .../PublicationResolver.cs | 128 +- .../QuantityKindFactorResolver.cs | 125 +- .../RatioScaleResolver.cs | 259 ++- .../ReferenceSourceResolver.cs | 241 ++- .../ReferencerRuleResolver.cs | 197 +- .../RelationalExpressionResolver.cs | 141 +- .../RelationshipParameterValueResolver.cs | 130 +- .../RequestForDeviationResolver.cs | 248 ++- .../RequestForWaiverResolver.cs | 248 ++- .../RequirementResolver.cs | 197 +- ...irementsContainerParameterValueResolver.cs | 130 +- .../RequirementsGroupResolver.cs | 178 +- .../RequirementsSpecificationResolver.cs | 196 +- .../ReviewItemDiscrepancyResolver.cs | 255 ++- .../RuleVerificationListResolver.cs | 161 +- .../RuleViolationResolver.cs | 121 +- .../SampledFunctionParameterTypeResolver.cs | 199 +- .../ScaleReferenceQuantityValueResolver.cs | 125 +- .../ScaleValueDefinitionResolver.cs | 157 +- .../AutoGenDtoDeserializer/SectionResolver.cs | 158 +- .../SharedStyleResolver.cs | 253 ++- .../SimpleParameterValueResolver.cs | 130 +- .../SimpleQuantityKindResolver.cs | 204 ++- .../SimpleUnitResolver.cs | 157 +- .../SiteDirectoryDataAnnotationResolver.cs | 172 +- ...SiteDirectoryDataDiscussionItemResolver.cs | 158 +- .../SiteDirectoryResolver.cs | 246 ++- .../SiteDirectoryThingReferenceResolver.cs | 125 +- .../SiteLogEntryResolver.cs | 186 +- .../SiteReferenceDataLibraryResolver.cs | 249 ++- .../SolutionResolver.cs | 158 +- .../SpecializedQuantityKindResolver.cs | 215 ++- .../StakeHolderValueMapResolver.cs | 188 +- .../StakeHolderValueMapSettingsResolver.cs | 136 +- .../StakeholderResolver.cs | 160 +- .../StakeholderValueResolver.cs | 153 +- .../TelephoneNumberResolver.cs | 121 +- .../AutoGenDtoDeserializer/TermResolver.cs | 157 +- .../TextParameterTypeResolver.cs | 175 +- .../TextualNoteResolver.cs | 176 +- .../TimeOfDayParameterTypeResolver.cs | 175 +- .../UnitFactorResolver.cs | 125 +- .../UnitPrefixResolver.cs | 168 +- .../UserPreferenceResolver.cs | 125 +- .../UserRuleVerificationResolver.cs | 148 +- .../ValueGroupResolver.cs | 153 +- .../ActionItemSerializer.cs | 1180 +++++++++++- .../ActualFiniteStateListSerializer.cs | 637 ++++++- .../ActualFiniteStateSerializer.cs | 517 +++++- .../AutoGenDtoSerializer/AliasSerializer.cs | 529 +++++- .../AndExpressionSerializer.cs | 481 ++++- .../ApprovalSerializer.cs | 607 +++++- .../ArrayParameterTypeSerializer.cs | 997 +++++++++- .../BinaryNoteSerializer.cs | 658 ++++++- .../BinaryRelationshipRuleSerializer.cs | 889 ++++++++- .../BinaryRelationshipSerializer.cs | 670 ++++++- .../AutoGenDtoSerializer/BookSerializer.cs | 643 ++++++- .../BooleanParameterTypeSerializer.cs | 805 +++++++- .../AutoGenDtoSerializer/BoundsSerializer.cs | 574 +++++- .../BuiltInRuleVerificationSerializer.cs | 660 ++++++- .../CategorySerializer.cs | 865 ++++++++- .../ChangeProposalSerializer.cs | 1054 ++++++++++- .../ChangeRequestSerializer.cs | 1021 ++++++++++- .../CitationSerializer.cs | 601 +++++- .../AutoGenDtoSerializer/ColorSerializer.cs | 565 +++++- .../CommonFileStoreSerializer.cs | 649 ++++++- .../CompoundParameterTypeSerializer.cs | 901 ++++++++- .../ConstantSerializer.cs | 899 ++++++++- .../ContractChangeNoticeSerializer.cs | 1054 ++++++++++- .../CyclicRatioScaleSerializer.cs | 1153 +++++++++++- .../DateParameterTypeSerializer.cs | 805 +++++++- .../DateTimeParameterTypeSerializer.cs | 805 +++++++- .../DecompositionRuleSerializer.cs | 913 ++++++++- .../DefinitionSerializer.cs | 673 ++++++- ...endentParameterTypeAssignmentSerializer.cs | 457 ++++- .../DerivedQuantityKindSerializer.cs | 997 +++++++++- .../DerivedUnitSerializer.cs | 769 +++++++- .../DiagramCanvasSerializer.cs | 577 +++++- .../DiagramEdgeSerializer.cs | 832 ++++++++- .../DiagramObjectSerializer.cs | 781 +++++++- .../DomainFileStoreSerializer.cs | 685 ++++++- .../DomainOfExpertiseGroupSerializer.cs | 769 +++++++- .../DomainOfExpertiseSerializer.cs | 769 +++++++- .../ElementDefinitionSerializer.cs | 1051 ++++++++++- .../ElementUsageSerializer.cs | 961 +++++++++- .../EmailAddressSerializer.cs | 493 ++++- ...eeringModelDataDiscussionItemSerializer.cs | 601 +++++- .../EngineeringModelDataNoteSerializer.cs | 703 ++++++- .../EngineeringModelSerializer.cs | 826 ++++++++- .../EngineeringModelSetupSerializer.cs | 1183 +++++++++++- .../EnumerationParameterTypeSerializer.cs | 901 ++++++++- .../EnumerationValueDefinitionSerializer.cs | 673 ++++++- .../ExclusiveOrExpressionSerializer.cs | 481 ++++- .../ExternalIdentifierMapSerializer.cs | 733 +++++++- .../FileRevisionSerializer.cs | 697 ++++++- .../AutoGenDtoSerializer/FileSerializer.cs | 649 ++++++- .../FileTypeSerializer.cs | 805 +++++++- .../AutoGenDtoSerializer/FolderSerializer.cs | 637 ++++++- .../GlossarySerializer.cs | 829 ++++++++- .../AutoGenDtoSerializer/GoalSerializer.cs | 679 ++++++- .../HyperLinkSerializer.cs | 529 +++++- .../IdCorrespondenceSerializer.cs | 493 ++++- ...endentParameterTypeAssignmentSerializer.cs | 457 ++++- .../IntervalScaleSerializer.cs | 1117 ++++++++++- .../IterationSerializer.cs | 1630 +++++++++++++++-- .../IterationSetupSerializer.cs | 745 +++++++- .../LinearConversionUnitSerializer.cs | 781 +++++++- .../LogEntryChangelogItemSerializer.cs | 511 +++++- .../LogarithmicScaleSerializer.cs | 1321 +++++++++++-- .../MappingToReferenceScaleSerializer.cs | 493 ++++- .../ModelLogEntrySerializer.cs | 859 ++++++++- .../ModelReferenceDataLibrarySerializer.cs | 1465 ++++++++++++++- .../ModellingThingReferenceSerializer.cs | 475 ++++- .../MultiRelationshipRuleSerializer.cs | 877 ++++++++- .../MultiRelationshipSerializer.cs | 658 ++++++- .../NaturalLanguageSerializer.cs | 529 +++++- .../NestedElementSerializer.cs | 613 ++++++- .../NestedParameterSerializer.cs | 673 ++++++- .../NotExpressionSerializer.cs | 457 ++++- .../AutoGenDtoSerializer/OptionSerializer.cs | 793 +++++++- .../OrExpressionSerializer.cs | 481 ++++- .../OrdinalScaleSerializer.cs | 1153 +++++++++++- .../OrganizationSerializer.cs | 529 +++++- .../OrganizationalParticipantSerializer.cs | 409 ++++- .../OwnedStyleSerializer.cs | 1186 +++++++++++- .../AutoGenDtoSerializer/PageSerializer.cs | 643 ++++++- .../ParameterGroupSerializer.cs | 529 +++++- .../ParameterOverrideSerializer.cs | 613 ++++++- .../ParameterOverrideValueSetSerializer.cs | 603 +++++- .../ParameterSerializer.cs | 1009 +++++++++- .../ParameterSubscriptionSerializer.cs | 517 +++++- ...ParameterSubscriptionValueSetSerializer.cs | 515 +++++- .../ParameterTypeComponentSerializer.cs | 565 +++++- .../ParameterValueSetSerializer.cs | 711 ++++++- .../ParameterizedCategoryRuleSerializer.cs | 805 +++++++- .../ParametricConstraintSerializer.cs | 553 +++++- .../ParticipantPermissionSerializer.cs | 529 +++++- .../ParticipantRoleSerializer.cs | 769 +++++++- .../ParticipantSerializer.cs | 625 ++++++- .../PersonPermissionSerializer.cs | 529 +++++- .../PersonRoleSerializer.cs | 769 +++++++- .../AutoGenDtoSerializer/PersonSerializer.cs | 1213 +++++++++++- .../AutoGenDtoSerializer/PointSerializer.cs | 508 ++++- .../PossibleFiniteStateListSerializer.cs | 901 ++++++++- .../PossibleFiniteStateSerializer.cs | 673 ++++++- .../PrefixedUnitSerializer.cs | 709 ++++++- .../PublicationSerializer.cs | 577 +++++- .../QuantityKindFactorSerializer.cs | 493 ++++- .../RatioScaleSerializer.cs | 1117 ++++++++++- .../ReferenceSourceSerializer.cs | 1165 +++++++++++- .../ReferencerRuleSerializer.cs | 877 ++++++++- .../RelationalExpressionSerializer.cs | 587 +++++- .../RelationshipParameterValueSerializer.cs | 522 +++++- .../RequestForDeviationSerializer.cs | 1021 ++++++++++- .../RequestForWaiverSerializer.cs | 1021 ++++++++++- .../RequirementSerializer.cs | 997 +++++++++- ...ementsContainerParameterValueSerializer.cs | 522 +++++- .../RequirementsGroupSerializer.cs | 871 ++++++++- .../RequirementsSpecificationSerializer.cs | 967 +++++++++- .../ReviewItemDiscrepancySerializer.cs | 1072 ++++++++++- .../RuleVerificationListSerializer.cs | 769 +++++++- .../RuleViolationSerializer.cs | 517 +++++- .../SampledFunctionParameterTypeSerializer.cs | 817 ++++++++- .../ScaleReferenceQuantityValueSerializer.cs | 493 ++++- .../ScaleValueDefinitionSerializer.cs | 709 ++++++- .../AutoGenDtoSerializer/SectionSerializer.cs | 643 ++++++- .../SerializerProvider.cs | 70 +- .../SharedStyleSerializer.cs | 1186 +++++++++++- .../SimpleParameterValueSerializer.cs | 551 +++++- .../SimpleQuantityKindSerializer.cs | 937 +++++++++- .../SimpleUnitSerializer.cs | 709 ++++++- .../SiteDirectoryDataAnnotationSerializer.cs | 676 ++++++- ...teDirectoryDataDiscussionItemSerializer.cs | 601 +++++- .../SiteDirectorySerializer.cs | 1360 +++++++++++++- .../SiteDirectoryThingReferenceSerializer.cs | 475 ++++- .../SiteLogEntrySerializer.cs | 859 ++++++++- .../SiteReferenceDataLibrarySerializer.cs | 1501 ++++++++++++++- .../SolutionSerializer.cs | 574 +++++- .../SpecializedQuantityKindSerializer.cs | 973 +++++++++- .../StakeHolderValueMapSerializer.cs | 934 +++++++++- .../StakeHolderValueMapSettingsSerializer.cs | 589 +++++- .../StakeholderSerializer.cs | 730 +++++++- .../StakeholderValueSerializer.cs | 679 ++++++- .../TelephoneNumberSerializer.cs | 517 +++++- .../AutoGenDtoSerializer/TermSerializer.cs | 709 ++++++- .../TextParameterTypeSerializer.cs | 805 +++++++- .../TextualNoteSerializer.cs | 658 ++++++- .../TimeOfDayParameterTypeSerializer.cs | 805 +++++++- .../UnitFactorSerializer.cs | 493 ++++- .../UnitPrefixSerializer.cs | 745 +++++++- .../UserPreferenceSerializer.cs | 493 ++++- .../UserRuleVerificationSerializer.cs | 660 ++++++- .../ValueGroupSerializer.cs | 679 ++++++- .../ActualFiniteStateKindDeserializer.cs | 64 + .../AnnotationApprovalKindDeserializer.cs | 65 + ...nnotationClassificationKindDeserializer.cs | 64 + .../AnnotationStatusKindDeserializer.cs | 68 + .../BooleanOperatorKindDeserializer.cs | 65 + .../ClassKindDeserializer.cs | 243 +++ .../EngineeringModelKindDeserializer.cs | 66 + .../InterfaceEndKindDeserializer.cs | 67 + .../LogEntryChangelogItemKindDeserializer.cs | 65 + .../LogLevelKindDeserializer.cs | 66 + .../LogarithmBaseKindDeserializer.cs | 65 + .../NumberSetKindDeserializer.cs | 66 + .../ParameterSwitchKindDeserializer.cs | 65 + .../ParticipantAccessRightKindDeserializer.cs | 69 + .../PersonAccessRightKindDeserializer.cs | 71 + .../RelationalOperatorKindDeserializer.cs | 68 + .../RuleVerificationStatusKindDeserializer.cs | 66 + .../StudyPhaseKindDeserializer.cs | 66 + .../VcardEmailAddressKindDeserializer.cs | 64 + .../VcardTelephoneNumberKindDeserializer.cs | 71 + CDP4JsonSerializer/CDP4JsonSerializer.csproj | 22 +- CDP4JsonSerializer/Cdp4JsonSerializer.cs | 178 +- .../DtoSerializer/BaseThingSerializer.cs | 40 +- .../DtoSerializer/IThingSerializer.cs | 51 +- CDP4JsonSerializer/Helper/SerializerHelper.cs | 130 +- CDP4JsonSerializer/ICdp4JsonSerializer.cs | 45 +- .../JsonConverter/ClassKindConverter.cs | 50 - .../JsonConverter/ClasslessDtoSerializer.cs | 174 +- .../JsonConverter/ThingConverterExtensions.cs | 111 ++ .../JsonConverter/ThingSerializer.cs | 157 +- CDP4JsonSerializer/Properties/AssemblyInfo.cs | 5 +- CDP4JsonSerializer/SerializerOptions.cs | 88 + .../CDP4ServicesDal.NetCore.Tests.csproj | 3 +- .../CdpServicesDalTestFixture.cs | 52 +- .../CopyOperationHandlerTestFixture.cs | 10 +- .../OperationModifierTestFixture.cs | 10 +- .../PostOperationTestFixture.cs | 47 +- .../CdpServicesDalTestFixture.cs | 51 +- .../CopyOperationHandlerTestFixture.cs | 10 +- .../OperationModifierTestFixture.cs | 12 +- .../PostOperationTestFixture.cs | 50 +- CDP4ServicesDal/CDP4ServicesDal.csproj | 7 +- CDP4ServicesDal/CdpPostOperation.cs | 47 +- CDP4ServicesDal/CdpServicesDal.cs | 45 +- CDP4ServicesDal/CopyOperationHandler.cs | 41 +- CDP4ServicesDal/OperationModifier.cs | 49 +- CDP4ServicesDal/ValueSetOperationCreator.cs | 43 +- .../CDP4ServicesMessaging.csproj | 2 +- .../Serializers/Json/Cdp4MessageSerializer.cs | 38 +- .../CopyOperationHandlerTestFixture.cs | 10 +- .../OperationModifierTestFixture.cs | 10 +- .../Operations/WSPPostOperationTestFixture.cs | 36 +- .../PostOperationTestFixture.cs | 67 +- CDP4WspDal.NetCore.Tests/WSPDalTestFixture.cs | 10 +- .../CopyOperationHandlerTestFixture.cs | 10 +- .../OperationModifierTestFixture.cs | 12 +- .../Operations/WSPPostOperationTestFixture.cs | 36 +- CDP4WspDal.Tests/PostOperationTestFixture.cs | 66 +- CDP4WspDal.Tests/WSPDalTestFixture.cs | 10 +- CDP4WspDal/CDP4WspDal.csproj | 2 +- CDP4WspDal/CopyOperationHandler.cs | 51 +- CDP4WspDal/OperationModifier.cs | 53 +- CDP4WspDal/ValueSetOperationCreator.cs | 49 +- CDP4WspDal/WSPDal.cs | 64 +- CDP4WspDal/WSPPostOperation.cs | 45 +- 402 files changed, 120489 insertions(+), 20963 deletions(-) rename {CDP4Dal => CDP4DalCommon/Protocol}/Operations/Operation.cs (79%) rename {CDP4Dal => CDP4DalCommon/Protocol}/Operations/OperationKind.cs (84%) rename {CDP4Dal => CDP4DalCommon/Protocol}/Operations/PostOperation.cs (80%) rename CDP4DalCommon/{ => Protocol}/Tasks/CometTask.cs (92%) rename CDP4DalCommon/{ => Protocol}/Tasks/StatusKind.cs (57%) create mode 100644 CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj create mode 100644 CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs create mode 100644 CDP4DalJsonSerializer/Extensions/JsonElementExtensions.cs create mode 100644 CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/ActualFiniteStateKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationApprovalKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationClassificationKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationStatusKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/BooleanOperatorKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/ClassKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/EngineeringModelKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/InterfaceEndKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/LogEntryChangelogItemKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/LogLevelKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/LogarithmBaseKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/NumberSetKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/ParameterSwitchKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/ParticipantAccessRightKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/PersonAccessRightKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/RelationalOperatorKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/RuleVerificationStatusKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/StudyPhaseKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/VcardEmailAddressKindDeserializer.cs create mode 100644 CDP4JsonSerializer/AutoGenEnumDeserializers/VcardTelephoneNumberKindDeserializer.cs delete mode 100644 CDP4JsonSerializer/JsonConverter/ClassKindConverter.cs create mode 100644 CDP4JsonSerializer/JsonConverter/ThingConverterExtensions.cs create mode 100644 CDP4JsonSerializer/SerializerOptions.cs diff --git a/CDP4-SDK.sln b/CDP4-SDK.sln index 4b54bcb1e..399349a7d 100644 --- a/CDP4-SDK.sln +++ b/CDP4-SDK.sln @@ -79,6 +79,8 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CDP4ServicesMessaging.Tests EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CDP4DalCommon", "CDP4DalCommon\CDP4DalCommon.csproj", "{E7CDB217-8442-4FD4-8E87-F4A8BFE9622A}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CDP4DalJsonSerializer", "CDP4DalJsonSerializer\CDP4DalJsonSerializer.csproj", "{36C38A02-C1CF-4F4F-AB40-F0A231256B30}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -209,6 +211,10 @@ Global {E7CDB217-8442-4FD4-8E87-F4A8BFE9622A}.Debug|Any CPU.Build.0 = Debug|Any CPU {E7CDB217-8442-4FD4-8E87-F4A8BFE9622A}.Release|Any CPU.ActiveCfg = Release|Any CPU {E7CDB217-8442-4FD4-8E87-F4A8BFE9622A}.Release|Any CPU.Build.0 = Release|Any CPU + {36C38A02-C1CF-4F4F-AB40-F0A231256B30}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {36C38A02-C1CF-4F4F-AB40-F0A231256B30}.Debug|Any CPU.Build.0 = Debug|Any CPU + {36C38A02-C1CF-4F4F-AB40-F0A231256B30}.Release|Any CPU.ActiveCfg = Release|Any CPU + {36C38A02-C1CF-4F4F-AB40-F0A231256B30}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/CDP4-SDK.sln.DotSettings b/CDP4-SDK.sln.DotSettings index bdc00e13d..b148fe695 100644 --- a/CDP4-SDK.sln.DotSettings +++ b/CDP4-SDK.sln.DotSettings @@ -246,7 +246,7 @@ <copyright file="${File.FileName}" company="RHEA System S.A."> Copyright (c) 2015-${CurrentDate.Year} RHEA System S.A. - Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar + Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar This file is part of CDP4-COMET SDK Community Edition diff --git a/CDP4Dal.NetCore.Tests/DAL/DalTestFixture.cs b/CDP4Dal.NetCore.Tests/DAL/DalTestFixture.cs index 769ec3409..1ced51854 100644 --- a/CDP4Dal.NetCore.Tests/DAL/DalTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/DAL/DalTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests.DAL { @@ -36,11 +36,12 @@ namespace CDP4Dal.Tests.DAL using CDP4Common.Helpers; using CDP4Dal.Composition; + using CDP4Dal.DAL; using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4Dal.DAL; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using NUnit.Framework; @@ -140,6 +141,7 @@ public void Verify_That_SetIterationId_Works_as_expected() var iteration = new Iteration(); var elementDefinition = new ElementDefinition(); var parameter = new Parameter(); + var list = new List { model, @@ -303,7 +305,10 @@ public void Verify_that_OperationContainerFileVerification_throws_no_exception_w [CDPVersion("1.1.0")] internal class TestDal : Dal { - public override bool IsReadOnly { get { return false; } } + public override bool IsReadOnly + { + get { return false; } + } public TestDal(Credentials credentials) : base() @@ -451,6 +456,7 @@ public override Task> CherryPick(Guid engineeringModelId, Gui internal class DecoratedDal : Dal { public override bool IsReadOnly { get; } + public override Task> Write(IEnumerable operationContainer, IEnumerable files = null) { throw new NotImplementedException(); @@ -566,4 +572,4 @@ public override Task> CherryPick(Guid engineeringModelId, Gui throw new NotSupportedException(); } } -} \ No newline at end of file +} diff --git a/CDP4Dal.NetCore.Tests/Operations/OperationContainerTestFixture.cs b/CDP4Dal.NetCore.Tests/Operations/OperationContainerTestFixture.cs index 4a38275e3..0fb7fadf3 100644 --- a/CDP4Dal.NetCore.Tests/Operations/OperationContainerTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/Operations/OperationContainerTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { @@ -28,10 +28,14 @@ namespace CDP4Dal.Tests using System.Linq; using CDP4Common.CommonData; - using CDP4Common.DTO; + using CDP4Common.DTO; + using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; - + [TestFixture] public class OperationContainerTestFixture { @@ -42,7 +46,7 @@ public class OperationContainerTestFixture [SetUp] public void SetUp() { - this.siteDirectoryContext = "/SiteDirectory/47363f0d-eb6d-4a58-95f5-fa7854995650"; + this.siteDirectoryContext = "/SiteDirectory/47363f0d-eb6d-4a58-95f5-fa7854995650"; this.iterationContext = "/EngineeringModel/5e5dc7f8-833d-4331-b421-eb2c64fcf64b/iteration/b58ea73d-350d-4520-b9d9-a52c75ac2b5d"; } @@ -98,9 +102,9 @@ public void VerifyExecutionOfOperationAddAndRemove() var elementDefinition = new ElementDefinition(Guid.NewGuid(), 0); elementDefinition.PartialRoutes.Add("iteration/b58ea73d-350d-4520-b9d9-a52c75ac2b5d"); elementDefinition.PartialRoutes.Add("EngineeringModel/5e5dc7f8-833d-4331-b421-eb2c64fcf64b"); - + var clone = elementDefinition.DeepClone(); - var operation = new Operation(elementDefinition, clone, OperationKind.Update); + var operation = new Operation(elementDefinition, clone, OperationKind.Update); var operationContainer = new OperationContainer(this.iterationContext); diff --git a/CDP4Dal.NetCore.Tests/Operations/OperationTestFixture.cs b/CDP4Dal.NetCore.Tests/Operations/OperationTestFixture.cs index 740b45252..c749e2325 100644 --- a/CDP4Dal.NetCore.Tests/Operations/OperationTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/Operations/OperationTestFixture.cs @@ -1,33 +1,33 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { using CDP4Common.DTO; - using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; [TestFixture] diff --git a/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs b/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs index 7e19fa6e2..6ded42c1c 100644 --- a/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs @@ -1,37 +1,37 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion - -using CDP4Common; +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { using System.Collections.Generic; + + using CDP4Common; using CDP4Common.Dto; using CDP4Common.DTO; - using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; [TestFixture] @@ -44,16 +44,20 @@ public void VerifyThatConstructorSetsLists() Assert.IsNotNull(testPostOperation.Delete); Assert.IsNotNull(testPostOperation.Create); Assert.IsNotNull(testPostOperation.Update); - Assert.IsNotNull(testPostOperation.Copy); + Assert.IsNotNull(testPostOperation.Copy); } } internal class TestPostOperation : PostOperation { public override List Delete { get; set; } + public override List Create { get; set; } + public override List Update { get; set; } + public override List Copy { get; set; } + public override void ConstructFromOperation(Operation operation) { throw new System.NotImplementedException(); diff --git a/CDP4Dal.NetCore.Tests/Operations/ThingTransactionTestFixture.cs b/CDP4Dal.NetCore.Tests/Operations/ThingTransactionTestFixture.cs index 55b96ae05..c0c750745 100644 --- a/CDP4Dal.NetCore.Tests/Operations/ThingTransactionTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/Operations/ThingTransactionTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { @@ -34,9 +34,11 @@ namespace CDP4Dal.Tests using CDP4Common.EngineeringModelData; using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - + using CDP4Dal.Operations; - + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; /// @@ -131,6 +133,7 @@ public void VerifyThatCreateThingWorksWithAbstractContainer() { Container = this.siteDirectory }; + this.cache.TryAdd(new CacheKey(siteRdl.Iid, null), new Lazy(() => siteRdl)); var cloneRdl = siteRdl.Clone(false); @@ -183,7 +186,7 @@ public void VerifyThatCreateThingTwiceDoesntThrowException() var transaction = new ThingTransaction(transactionContext, this.siteDirectory.Clone(false)); var phone = new TelephoneNumber(Guid.NewGuid(), this.cache, this.uri); - Assert.That(() => + Assert.That(() => { transaction.Create(phone); transaction.Create(phone); @@ -246,7 +249,6 @@ public void VerifyThatDeleteThingAlreadyDeletedWorks() [Test] public void VerifyThatUpdateContainerWorks() { - var iterationClone = this.iteration.Clone(false); var option1 = new Option(Guid.NewGuid(), this.cache, this.uri); @@ -328,6 +330,7 @@ public void FunctionalTestCase1() emailTrans.Create(email); emailTrans.FinalizeSubTransaction(email, person1_1); + // end add email, verify that email is added to person1_1, (the clone of person1) Assert.AreEqual(2, person1_1Tr.AddedThing.Count()); @@ -339,6 +342,7 @@ public void FunctionalTestCase1() var phone_1Trans = new ThingTransaction(phone_1, person1_1Tr, person1_1); phone_1Trans.CreateOrUpdate(phone_1); phone_1Trans.FinalizeSubTransaction(phone_1, person1_1); + // end update phone // verify that the new reference is used @@ -354,7 +358,6 @@ public void FunctionalTestCase1() Assert.IsTrue(rootTransaction.AddedThing.Contains(phone_1)); Assert.AreEqual(1, cloneSiteDir.Person.Count); - // Create new person var person2 = new Person(); var person2Trans = new ThingTransaction(person2, rootTransaction, cloneSiteDir); @@ -496,7 +499,6 @@ public void FunctionalTestCase2() Assert.IsTrue(siteDirClone.SiteReferenceDataLibrary.Contains(srdl2)); Assert.IsTrue(srdl2.Unit.Contains(unit2)); - // update site rdl1 var srdlC2 = siterdlC1.Clone(false); var srdlC2TRans = new ThingTransaction(srdlC2, rootTransaction, siteDirClone); @@ -829,6 +831,7 @@ public void VerifyThatCascadeDeleteWorksOnAddedThing() transaction.Delete(person.Clone(false)); var operationContainer = transaction.FinalizeTransaction(); + // Update sitedir Assert.AreEqual(1, operationContainer.Operations.Count()); } diff --git a/CDP4Dal.NetCore.Tests/SessionTestFixture.cs b/CDP4Dal.NetCore.Tests/SessionTestFixture.cs index d8e13ce03..ee986c74a 100644 --- a/CDP4Dal.NetCore.Tests/SessionTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/SessionTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.NetCore.Tests { @@ -37,17 +37,18 @@ namespace CDP4Dal.NetCore.Tests using CDP4Common.Types; using CDP4Dal.Composition; - using CDP4Dal.Operations; using CDP4Dal.DAL; using CDP4Dal.Events; using CDP4Dal.Exceptions; + using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using Moq; - + using NUnit.Framework; - + using DomainOfExpertise = CDP4Common.SiteDirectoryData.DomainOfExpertise; using EngineeringModelSetup = CDP4Common.DTO.EngineeringModelSetup; using ModelReferenceDataLibrary = CDP4Common.SiteDirectoryData.ModelReferenceDataLibrary; @@ -129,10 +130,7 @@ public void TearDown() public async Task VerifythatOpenCallAssemblerSynchronizeWithDtos() { var eventReceived = false; - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); await this.session.Open(); @@ -149,20 +147,20 @@ public async Task VerifyThatWriteWithEmptyResponseSendsMessages() writeWithNoResultsTaskCompletionSource.SetResult(new List()); this.mockedDal.Setup(x => x.Open(It.IsAny(), It.IsAny())).Returns(writeWithNoResultsTaskCompletionSource.Task); - this.messageBus.Listen() - .Subscribe(x => - { - if (x.Status == SessionStatus.BeginUpdate) + this.messageBus.Listen() + .Subscribe(x => { - beginUpdateReceived = true; - return; - } + if (x.Status == SessionStatus.BeginUpdate) + { + beginUpdateReceived = true; + return; + } - if (x.Status == SessionStatus.EndUpdate) - { - endUpdateReceived = true; - } - }); + if (x.Status == SessionStatus.EndUpdate) + { + endUpdateReceived = true; + } + }); var context = $"/SiteDirectory/{Guid.NewGuid()}"; @@ -186,13 +184,10 @@ public async Task VerifythatRefreshSynchronizeTheAssembler() var readTaskCompletionSource = new TaskCompletionSource>(); readTaskCompletionSource.SetResult(this.dalOutputs); this.mockedDal.Setup(x => x.Read(It.IsAny(), It.IsAny(), It.Is(query => query.RevisionNumber == 0))).Returns(readTaskCompletionSource.Task); - + await this.session.Open(); - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); // refresh shouldnt do anything await this.session.Refresh(); @@ -216,10 +211,7 @@ public async Task VerifythatReloadSynchronizeTheAssembler() await this.session.Open(); - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); await this.session.Reload(); @@ -277,10 +269,10 @@ public async Task VerifyThatCloseRdlWorks() var rdlDto = new CDP4Common.DTO.SiteReferenceDataLibrary { Iid = Guid.NewGuid() }; var rdlPoco = new CDP4Common.SiteDirectoryData.SiteReferenceDataLibrary { Iid = rdlDto.Iid, Name = rdlDto.Name, ShortName = rdlDto.ShortName, Container = siteDirectoryPoco }; - + var requiredSiteReferenceDataLibraryDto = new CDP4Common.DTO.SiteReferenceDataLibrary() { Iid = Guid.NewGuid() }; var requiredSiteReferenceDataLibraryPoco = new CDP4Common.SiteDirectoryData.SiteReferenceDataLibrary(requiredSiteReferenceDataLibraryDto.Iid, this.session.Assembler.Cache, this.uri); - + rdlDto.RequiredRdl = requiredSiteReferenceDataLibraryDto.Iid; rdlPoco.RequiredRdl = requiredSiteReferenceDataLibraryPoco; @@ -303,7 +295,7 @@ public async Task VerifyThatCloseRdlWorks() Lazy requiredRdlToClose; session.Assembler.Cache.TryGetValue(new CacheKey(requiredSiteReferenceDataLibraryPoco.Iid, null), out requiredRdlToClose); await session.CloseRdl((CDP4Common.SiteDirectoryData.SiteReferenceDataLibrary)requiredRdlToClose.Value); - + Assert.AreEqual(0, session.OpenReferenceDataLibraries.ToList().Count); await session.CloseRdl((CDP4Common.SiteDirectoryData.SiteReferenceDataLibrary)rdlPocoToClose.Value); @@ -319,7 +311,7 @@ public async Task VerifyThatSiteRdlRequiredByModelRdlCannotBeClosed() rdlDto.RequiredRdl = requiredRdlDto.Iid; siteDirDto.SiteReferenceDataLibrary.Add(rdlDto.Iid); siteDirDto.SiteReferenceDataLibrary.Add(requiredRdlDto.Iid); - + siteDirDto.Person.Add(this.person.Iid); var mrdl = new CDP4Common.DTO.ModelReferenceDataLibrary(Guid.NewGuid(), 0) { RequiredRdl = requiredRdlDto.Iid }; @@ -348,14 +340,15 @@ public async Task VerifyThatSiteRdlRequiredByModelRdlCannotBeClosed() var participant = new CDP4Common.DTO.Participant(Guid.NewGuid(), 0) { Person = this.person.Iid }; modelsetup.Participant.Add(participant.Iid); - var modelPoco = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null){EngineeringModelSetup = modelsetuppoco}; + var modelPoco = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null) { EngineeringModelSetup = modelsetuppoco }; var iterationPoco = new CDP4Common.EngineeringModelData.Iteration(iteration.Iid, null, null); modelPoco.Iteration.Add(iterationPoco); var readTaskCompletionSource = new TaskCompletionSource>(); readTaskCompletionSource.SetResult(readReturn); + this.mockedDal.Setup( - x => x.Read(It.IsAny(), It.IsAny(), null)) + x => x.Read(It.IsAny(), It.IsAny(), null)) .Returns(readTaskCompletionSource.Task); var thingsToAdd = new List() { siteDirDto, requiredRdlDto, rdlDto, this.person, participant, modelsetup }; @@ -365,7 +358,7 @@ public async Task VerifyThatSiteRdlRequiredByModelRdlCannotBeClosed() this.session.GetType().GetProperty("ActivePerson").SetValue(this.session, JohnDoe, null); await this.session.Read(iterationPoco, null); - + Assert.AreEqual(2, this.session.OpenReferenceDataLibraries.Count()); Lazy requiredRdlToClose; @@ -389,7 +382,7 @@ public async Task VerifyThatCloseModelRdlWorks() siteDir.Model.Add(containerEngModelSetup); modelRdlDto.RequiredRdl = requiredPocoDto.Iid; siteDir.Person.Add(JohnDoe); - + var credentials = new Credentials("admin", "pass", new Uri("http://www.rheagroup.com")); var session2 = new Session(this.mockedDal.Object, credentials, this.messageBus); session2.GetType().GetProperty("ActivePerson").SetValue(session2, JohnDoe, null); @@ -449,6 +442,7 @@ public async Task VerifyThatReadRdlWorks() { var siteDir = new CDP4Common.SiteDirectoryData.SiteDirectory(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; + this.session.Assembler.Cache.TryAdd(new CacheKey(siteDir.Iid, null), new Lazy(() => siteDir)); @@ -518,14 +512,14 @@ public async Task Verify_that_EngineeringModel_returns_result() await this.session.Read(iids); - Assert.That(this.session.Assembler.Cache.ContainsKey(new CacheKey(engineeringModel.Iid, null)), Is.True); + Assert.That(this.session.Assembler.Cache.ContainsKey(new CacheKey(engineeringModel.Iid, null)), Is.True); } [Test] public async Task VerifyThatReadIterationWorks() { var siteDir = new CDP4Common.SiteDirectoryData.SiteDirectory(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); - var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) {ShortName = "John"}; + var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; var modelSetup = new CDP4Common.SiteDirectoryData.EngineeringModelSetup(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); var iterationSetup = new CDP4Common.SiteDirectoryData.IterationSetup(Guid.NewGuid(), this.session.Assembler.Cache, this.uri) { FrozenOn = DateTime.Now, IterationIid = Guid.NewGuid() }; var mrdl = new ModelReferenceDataLibrary(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); @@ -570,7 +564,7 @@ public async Task VerifyThatReadIterationWorks() var iterationToOpen = new CDP4Common.EngineeringModelData.Iteration(iteration.Iid, null, null); var modelToOpen = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null); iterationToOpen.Container = modelToOpen; - + await this.session.Read(iterationToOpen, activeDomain); this.mockedDal.Verify(x => x.Read(It.Is(i => i.Iid == iterationToOpen.Iid), It.IsAny(), It.IsAny()), Times.Once); @@ -607,7 +601,7 @@ public void Verify_that_when_active_person_is_null_Iteration_is_not_read() var activeDomain = new DomainOfExpertise(Guid.NewGuid(), null, null); var model = new EngineeringModel(Guid.NewGuid(), 1); var iteration = new Iteration(Guid.NewGuid(), 10) { IterationSetup = iterationSetup.Iid }; - + var iterationToOpen = new CDP4Common.EngineeringModelData.Iteration(iteration.Iid, null, null); var modelToOpen = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null); iterationToOpen.Container = modelToOpen; @@ -623,7 +617,7 @@ public void VeriyThatCDPVersionIsSet() this.session = new Session(testDal, credentials, this.messageBus); var version = new Version("1.1.0"); - + Assert.AreEqual(version.Major, this.session.DalVersion.Major); Assert.AreEqual(version.Minor, this.session.DalVersion.Minor); Assert.AreEqual(version.Build, this.session.DalVersion.Build); @@ -664,10 +658,7 @@ public async Task VerifyThatWriteWorksWithEventHandler() var johnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; this.session.GetType().GetProperty("ActivePerson")?.SetValue(this.session, johnDoe, null); - this.session.BeforeWrite += (o, args) => - { - args.Cancelled = false; - }; + this.session.BeforeWrite += (o, args) => { args.Cancelled = false; }; await this.session.Write(new OperationContainer(context)); @@ -681,10 +672,7 @@ public void VerifyThatCancelWriteWorks() var johnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; this.session.GetType().GetProperty("ActivePerson")?.SetValue(this.session, johnDoe, null); - this.session.BeforeWrite += (o, args) => - { - args.Cancelled = true; - }; + this.session.BeforeWrite += (o, args) => { args.Cancelled = true; }; Assert.ThrowsAsync(async () => await this.session.Write(new OperationContainer(context))); @@ -746,11 +734,11 @@ public async Task VerifyCanReadCometTasks() var returnedCometTasks = new List() { - new () + new() { Id = Guid.NewGuid() }, - new () + new() { Id = Guid.NewGuid() }, @@ -788,7 +776,7 @@ public async Task VerifyWritePossibleLongRunningTask() this.mockedDal.Setup(x => x.Write(It.IsAny(), It.IsAny(), It.IsAny>())) .ReturnsAsync(new LongRunningTaskResult(new CometTask() { Id = Guid.Empty })); - + var cometTask = await this.session.Write(new OperationContainer(context), 1); Assert.Multiple(() => @@ -817,7 +805,7 @@ public async Task VerifyWritePossibleLongRunningTask() this.mockedDal.Setup(x => x.Write(It.IsAny(), It.IsAny(), It.IsAny>())) .ThrowsAsync(new DalReadException()); - Assert.That(() =>this.session.Write(new OperationContainer(context), 1), Throws.Exception.TypeOf()); + Assert.That(() => this.session.Write(new OperationContainer(context), 1), Throws.Exception.TypeOf()); } private void AssignActivePerson() @@ -830,17 +818,30 @@ private void AssignActivePerson() [DalExport("test dal", "test dal description", "1.1.0", DalType.Web)] internal class TestDal : IDal { - public Version SupportedVersion { get {return new Version(1, 0, 0);} } + public Version SupportedVersion + { + get { return new Version(1, 0, 0); } + } - public Version DalVersion { get {return new Version("1.1.0");} } - public IMetaDataProvider MetaDataProvider { get {return new MetaDataProvider();} } + public Version DalVersion + { + get { return new Version("1.1.0"); } + } + + public IMetaDataProvider MetaDataProvider + { + get { return new MetaDataProvider(); } + } /// /// Gets or sets the that uses this /// public ISession Session { get; set; } - public bool IsReadOnly { get { return false; } } + public bool IsReadOnly + { + get { return false; } + } /// /// Write all the s from all the s asynchronously. @@ -958,7 +959,7 @@ public Task> Read(Iteration iteration, CancellationToken canc /// A list of s /// /// - /// Only those s are retunred that the is a in + /// Only those s are retunred that the is a in /// public Task> Read(IEnumerable engineeringModels, CancellationToken cancellationToken) { @@ -1097,4 +1098,4 @@ public Task> CherryPick(Guid engineeringModelId, Guid iterati throw new System.NotImplementedException(); } } -} \ No newline at end of file +} diff --git a/CDP4Dal.Tests/DAL/DalTestFixture.cs b/CDP4Dal.Tests/DAL/DalTestFixture.cs index beb304103..2645f9d1a 100644 --- a/CDP4Dal.Tests/DAL/DalTestFixture.cs +++ b/CDP4Dal.Tests/DAL/DalTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests.DAL { @@ -36,11 +36,11 @@ namespace CDP4Dal.Tests.DAL using CDP4Common.Helpers; using CDP4Dal.Composition; + using CDP4Dal.DAL; using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4Dal.DAL; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Tasks; using NUnit.Framework; @@ -64,7 +64,7 @@ public void SetUp() [Test] public void Verify_that_the_credentials_are_set_to_Null_when_closed() { - var dal = new TestDal(this.credentials); + var dal = new TestDal(this.credentials); dal.CloseSession(); Assert.IsNull(dal.Credentials); } @@ -140,6 +140,7 @@ public void Verify_That_SetIterationId_Works_as_expected() var iteration = new Iteration(); var elementDefinition = new ElementDefinition(); var parameter = new Parameter(); + var list = new List { model, @@ -206,7 +207,7 @@ public void Verify_that_when_SetIterationContainer_is_called_with_empty_guid_exc public void Verify_That_QueryRequestContext_Returns_Expected_Result() { var testdal = new TestDal(this.credentials); - + var elementDefinitionUri = new Uri("http://www.rheagroup.com/EngineeringModel/00B1FD7E-BE0F-4512-A406-02FCBD63E06A/iteration/0111A76D-346D-4055-A78D-B8215B993DA1/element/E9E8E386-B8BB-44F1-80B9-2C30761EE688"); var elementDefinitionContext = testdal.QueryRequestContext(elementDefinitionUri); Assert.AreEqual("/EngineeringModel/00B1FD7E-BE0F-4512-A406-02FCBD63E06A/iteration/0111A76D-346D-4055-A78D-B8215B993DA1", elementDefinitionContext); @@ -216,7 +217,7 @@ public void Verify_That_QueryRequestContext_Returns_Expected_Result() public void Verify_that_for_a_decorated_dal_the_version_is_set() { var dal = new DecoratedDal(); - Assert.That(dal.DalVersion, Is.EqualTo(new Version(1,1,0))); + Assert.That(dal.DalVersion, Is.EqualTo(new Version(1, 1, 0))); } [Test] @@ -238,7 +239,7 @@ public void Verify_that_OperationContainerFileVerification_throws_an_exception_w var commonFileStore = new CDP4Common.EngineeringModelData.CommonFileStore(Guid.NewGuid(), null, null); engineeringModel.Iteration.Add(iteration); engineeringModel.CommonFileStore.Add(commonFileStore); - + var context = TransactionContextResolver.ResolveContext(commonFileStore); var transaction = new ThingTransaction(context); @@ -246,13 +247,13 @@ public void Verify_that_OperationContainerFileVerification_throws_an_exception_w var file = new CDP4Common.EngineeringModelData.File(Guid.NewGuid(), null, null); var fileRevision = new CDP4Common.EngineeringModelData.FileRevision(Guid.NewGuid(), null, null); - + transaction.Create(file, commonFileStoreClone); transaction.Create(fileRevision, file); var operationContainer = transaction.FinalizeTransaction(); - var files = new List {this.filePath}; + var files = new List { this.filePath }; var testDal = new TestDal(this.credentials); Assert.Throws(() => testDal.TestOperationContainerFileVerification(operationContainer, files)); @@ -277,7 +278,7 @@ public void Verify_that_OperationContainerFileVerification_throws_no_exception_w var commonFileStore = new CDP4Common.EngineeringModelData.CommonFileStore(Guid.NewGuid(), null, null); engineeringModel.Iteration.Add(iteration); engineeringModel.CommonFileStore.Add(commonFileStore); - + var context = TransactionContextResolver.ResolveContext(commonFileStore); var transaction = new ThingTransaction(context); @@ -286,13 +287,13 @@ public void Verify_that_OperationContainerFileVerification_throws_no_exception_w var file = new CDP4Common.EngineeringModelData.File(Guid.NewGuid(), null, null); var fileRevision = new CDP4Common.EngineeringModelData.FileRevision(Guid.NewGuid(), null, null); fileRevision.ContentHash = "1B686ADFA2CAE870A96E5885087337C032781BE6"; - + transaction.Create(file, commonFileStoreClone); transaction.Create(fileRevision, file); var operationContainer = transaction.FinalizeTransaction(); - var files = new List {this.filePath}; + var files = new List { this.filePath }; var testDal = new TestDal(this.credentials); @@ -300,10 +301,13 @@ public void Verify_that_OperationContainerFileVerification_throws_no_exception_w } } - [CDPVersion("1.1.0")] + [CDPVersion("1.1.0")] internal class TestDal : Dal { - public override bool IsReadOnly { get { return false; } } + public override bool IsReadOnly + { + get { return false; } + } public TestDal(Credentials credentials) : base() @@ -410,7 +414,7 @@ public override IEnumerable Update(T thing) { throw new System.NotImplementedException(); } - + public override IEnumerable Delete(T thing) { throw new System.NotImplementedException(); @@ -447,10 +451,11 @@ public override Task> CherryPick(Guid engineeringModelId, Gui } } - [DalExportAttribute("decorateddal","a decorated dal","1.1.0",DalType.Web)] + [DalExportAttribute("decorateddal", "a decorated dal", "1.1.0", DalType.Web)] internal class DecoratedDal : Dal { public override bool IsReadOnly { get; } + public override Task> Write(IEnumerable operationContainer, IEnumerable files = null) { throw new NotImplementedException(); @@ -566,4 +571,4 @@ public override Task> CherryPick(Guid engineeringModelId, Gui throw new NotSupportedException(); } } -} \ No newline at end of file +} diff --git a/CDP4Dal.Tests/Operations/OperationContainerTestFixture.cs b/CDP4Dal.Tests/Operations/OperationContainerTestFixture.cs index 4a38275e3..0fb7fadf3 100644 --- a/CDP4Dal.Tests/Operations/OperationContainerTestFixture.cs +++ b/CDP4Dal.Tests/Operations/OperationContainerTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { @@ -28,10 +28,14 @@ namespace CDP4Dal.Tests using System.Linq; using CDP4Common.CommonData; - using CDP4Common.DTO; + using CDP4Common.DTO; + using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; - + [TestFixture] public class OperationContainerTestFixture { @@ -42,7 +46,7 @@ public class OperationContainerTestFixture [SetUp] public void SetUp() { - this.siteDirectoryContext = "/SiteDirectory/47363f0d-eb6d-4a58-95f5-fa7854995650"; + this.siteDirectoryContext = "/SiteDirectory/47363f0d-eb6d-4a58-95f5-fa7854995650"; this.iterationContext = "/EngineeringModel/5e5dc7f8-833d-4331-b421-eb2c64fcf64b/iteration/b58ea73d-350d-4520-b9d9-a52c75ac2b5d"; } @@ -98,9 +102,9 @@ public void VerifyExecutionOfOperationAddAndRemove() var elementDefinition = new ElementDefinition(Guid.NewGuid(), 0); elementDefinition.PartialRoutes.Add("iteration/b58ea73d-350d-4520-b9d9-a52c75ac2b5d"); elementDefinition.PartialRoutes.Add("EngineeringModel/5e5dc7f8-833d-4331-b421-eb2c64fcf64b"); - + var clone = elementDefinition.DeepClone(); - var operation = new Operation(elementDefinition, clone, OperationKind.Update); + var operation = new Operation(elementDefinition, clone, OperationKind.Update); var operationContainer = new OperationContainer(this.iterationContext); diff --git a/CDP4Dal.Tests/Operations/OperationTestFixture.cs b/CDP4Dal.Tests/Operations/OperationTestFixture.cs index 740b45252..c749e2325 100644 --- a/CDP4Dal.Tests/Operations/OperationTestFixture.cs +++ b/CDP4Dal.Tests/Operations/OperationTestFixture.cs @@ -1,33 +1,33 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { using CDP4Common.DTO; - using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; [TestFixture] diff --git a/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs b/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs index 7e19fa6e2..6ded42c1c 100644 --- a/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs +++ b/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs @@ -1,37 +1,37 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion - -using CDP4Common; +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { using System.Collections.Generic; + + using CDP4Common; using CDP4Common.Dto; using CDP4Common.DTO; - using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; [TestFixture] @@ -44,16 +44,20 @@ public void VerifyThatConstructorSetsLists() Assert.IsNotNull(testPostOperation.Delete); Assert.IsNotNull(testPostOperation.Create); Assert.IsNotNull(testPostOperation.Update); - Assert.IsNotNull(testPostOperation.Copy); + Assert.IsNotNull(testPostOperation.Copy); } } internal class TestPostOperation : PostOperation { public override List Delete { get; set; } + public override List Create { get; set; } + public override List Update { get; set; } + public override List Copy { get; set; } + public override void ConstructFromOperation(Operation operation) { throw new System.NotImplementedException(); diff --git a/CDP4Dal.Tests/Operations/ThingTransactionTestFixture.cs b/CDP4Dal.Tests/Operations/ThingTransactionTestFixture.cs index 8be01a270..c0c750745 100644 --- a/CDP4Dal.Tests/Operations/ThingTransactionTestFixture.cs +++ b/CDP4Dal.Tests/Operations/ThingTransactionTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { @@ -31,12 +31,14 @@ namespace CDP4Dal.Tests using System.Text; using CDP4Common.CommonData; - using CDP4Common.EngineeringModelData; + using CDP4Common.EngineeringModelData; using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - + using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; /// @@ -51,7 +53,7 @@ public class ThingTransactionTestFixture private ConcurrentDictionary> cache; private Uri uri = new Uri("http://www.rheagroup.com"); - + [SetUp] public void Setup() { @@ -65,7 +67,7 @@ public void Setup() iterationSetup.IterationIid = this.iteration.Iid; this.engineeringModel.Iteration.Add(this.iteration); - + this.cache.TryAdd(new CacheKey(this.siteDirectory.Iid, null), new Lazy(() => this.siteDirectory)); this.cache.TryAdd(new CacheKey(this.engineeringModel.Iid, null), new Lazy(() => this.engineeringModel)); this.cache.TryAdd(new CacheKey(this.iteration.Iid, null), new Lazy(() => this.iteration)); @@ -85,7 +87,7 @@ public void VerifyThatFilePathsAreReturned() var transaction = new ThingTransaction(transactionContext, fileRevision1); transaction.CreateOrUpdate(fileRevision2); - CollectionAssert.AreEqual(transaction.GetFiles(), new [] { filePath }); + CollectionAssert.AreEqual(transaction.GetFiles(), new[] { filePath }); } [Test] @@ -95,7 +97,7 @@ public void VerifyThatCanOnlyUseThingTransactionOnOneTopContainer() var person = new Person(Guid.NewGuid(), this.cache, this.uri) { Container = this.siteDirectory }; var transaction = new ThingTransaction(transactionContext, person); - + var duplicateSiteDirectory = new SiteDirectory(this.siteDirectory.Iid, this.cache, this.uri); var anotherPerson = new Person(Guid.NewGuid(), this.cache, this.uri) { Container = duplicateSiteDirectory }; transaction.CreateOrUpdate(anotherPerson); @@ -109,7 +111,7 @@ public void VerifyThatCanOnlyUseThingTransactionOnOneTopContainer() [Test] public void VerifyThatCreateThingWorks() { - var person = new Person(Guid.NewGuid(), this.cache, this.uri) {Container = this.siteDirectory}; + var person = new Person(Guid.NewGuid(), this.cache, this.uri) { Container = this.siteDirectory }; this.cache.TryAdd(new CacheKey(person.Iid, null), new Lazy(() => person)); var clonePerson = person.Clone(false); @@ -131,6 +133,7 @@ public void VerifyThatCreateThingWorksWithAbstractContainer() { Container = this.siteDirectory }; + this.cache.TryAdd(new CacheKey(siteRdl.Iid, null), new Lazy(() => siteRdl)); var cloneRdl = siteRdl.Clone(false); @@ -152,7 +155,7 @@ public void VerifyThatCreateModelDoesNotWorks() var newModel = new EngineeringModel(Guid.NewGuid(), this.cache, this.uri); var transactionContext = TransactionContextResolver.ResolveContext(this.siteDirectory); - + Assert.Throws(() => new ThingTransaction(transactionContext, newModel)); } @@ -162,7 +165,7 @@ public void VerifyThatCreateSiteDirDoesNotWorks() var newSiteDirectory = new SiteDirectory(Guid.NewGuid(), this.cache, this.uri); var transactionContext = TransactionContextResolver.ResolveContext(this.siteDirectory); - + Assert.Throws(() => new ThingTransaction(transactionContext, newSiteDirectory)); } @@ -195,7 +198,7 @@ public void VerifyThatUpdateThingWorks() { var phone = new TelephoneNumber(Guid.NewGuid(), this.cache, this.uri); this.cache.TryAdd(new CacheKey(phone.Iid, null), new Lazy(() => phone)); - + var clone = phone.Clone(false); var transactionContext = TransactionContextResolver.ResolveContext(this.siteDirectory); @@ -208,9 +211,9 @@ public void VerifyThatUpdateThingWorks() [Test] public void VerifyThatUpdateThingThrowsExceptionUponUpdatingExistingCloneWithAnotherClone() { - var phone = new TelephoneNumber(Guid.NewGuid(), this.cache, this.uri); + var phone = new TelephoneNumber(Guid.NewGuid(), this.cache, this.uri); this.cache.TryAdd(new CacheKey(phone.Iid, null), new Lazy(() => phone)); - + var clone1 = phone.Clone(false); var clone2 = phone.Clone(false); @@ -246,10 +249,9 @@ public void VerifyThatDeleteThingAlreadyDeletedWorks() [Test] public void VerifyThatUpdateContainerWorks() { - var iterationClone = this.iteration.Clone(false); var option1 = new Option(Guid.NewGuid(), this.cache, this.uri); - + var transactionContext = TransactionContextResolver.ResolveContext(this.iteration); var transaction = new ThingTransaction(transactionContext, iterationClone); transaction.CreateOrUpdate(iterationClone); @@ -272,7 +274,7 @@ public void VerifyThatUpdateContainerWorks() Assert.AreEqual(0, this.iteration.Option.Count); Assert.AreEqual(2, clone.Option.Count); } - + /// /// Create a containment tree under site directory and update /// @@ -328,6 +330,7 @@ public void FunctionalTestCase1() emailTrans.Create(email); emailTrans.FinalizeSubTransaction(email, person1_1); + // end add email, verify that email is added to person1_1, (the clone of person1) Assert.AreEqual(2, person1_1Tr.AddedThing.Count()); @@ -339,6 +342,7 @@ public void FunctionalTestCase1() var phone_1Trans = new ThingTransaction(phone_1, person1_1Tr, person1_1); phone_1Trans.CreateOrUpdate(phone_1); phone_1Trans.FinalizeSubTransaction(phone_1, person1_1); + // end update phone // verify that the new reference is used @@ -353,7 +357,7 @@ public void FunctionalTestCase1() Assert.IsTrue(cloneSiteDir.Person.Contains(person1_1)); Assert.IsTrue(rootTransaction.AddedThing.Contains(phone_1)); Assert.AreEqual(1, cloneSiteDir.Person.Count); - + // Create new person var person2 = new Person(); var person2Trans = new ThingTransaction(person2, rootTransaction, cloneSiteDir); @@ -495,7 +499,6 @@ public void FunctionalTestCase2() Assert.IsTrue(siteDirClone.SiteReferenceDataLibrary.Contains(srdl2)); Assert.IsTrue(srdl2.Unit.Contains(unit2)); - // update site rdl1 var srdlC2 = siterdlC1.Clone(false); var srdlC2TRans = new ThingTransaction(srdlC2, rootTransaction, siteDirClone); @@ -578,7 +581,7 @@ public void VerifyThatCreateDeepWorks() enumValue.Definition.Add(enumValueDef); enumPt.ValueDefinition.Add(enumValue); - + var transactionContext = TransactionContextResolver.ResolveContext(this.siteDirectory); var transaction = new ThingTransaction(transactionContext); transaction.CreateDeep(enumPt); @@ -828,6 +831,7 @@ public void VerifyThatCascadeDeleteWorksOnAddedThing() transaction.Delete(person.Clone(false)); var operationContainer = transaction.FinalizeTransaction(); + // Update sitedir Assert.AreEqual(1, operationContainer.Operations.Count()); } @@ -853,8 +857,8 @@ public void VerifyThatDryCopyWorks() var elementDefinitionClone = elementDefinition.Clone(false); var targetIterationClone = targetIteration.Clone(false); - - var transactionContext = TransactionContextResolver.ResolveContext(targetIteration); + + var transactionContext = TransactionContextResolver.ResolveContext(targetIteration); var transaction = new ThingTransaction(transactionContext); transaction.Copy(elementDefinitionClone, targetIterationClone, OperationKind.CopyDefaultValuesChangeOwner); @@ -887,7 +891,7 @@ public void VerifyThatCtrlCopyWorks() var elementDefinitionClone = elementDefinition.Clone(false); var targetIterationClone = targetIteration.Clone(false); - + var transactionContext = TransactionContextResolver.ResolveContext(targetIteration); var transaction = new ThingTransaction(transactionContext); transaction.Copy(elementDefinitionClone, targetIterationClone, OperationKind.CopyKeepValuesChangeOwner); @@ -995,7 +999,7 @@ public void VerifyThatWhenCopyOperationIsInvokedWithNonCopyOperationExceptionIsT Assert.Throws(() => transaction.Copy(elementDefinitionClone, targetIterationClone, OperationKind.Create)); } - [Test] + [Test] public void VerifyThatCopyThrowsExcpetionCloneThatIsToBeCopiedIsNull() { var sourceModel = new EngineeringModel(Guid.NewGuid(), this.cache, this.uri); @@ -1020,7 +1024,7 @@ public void VerifyThatCopyThrowsExcpetionCloneThatIsToBeCopiedIsNull() Assert.Throws(() => transaction.Copy(null, OperationKind.Copy)); } - [Test] + [Test] public void VerifyThatCopyThrowsExceptionWhenDestinationIsNull() { var sourceModel = new EngineeringModel(Guid.NewGuid(), this.cache, this.uri); @@ -1051,9 +1055,9 @@ public void VerifyThatGetLastCloneCreatedThrowsExceptionWhenThingIsNullOrGuidIsE { var model = new EngineeringModel(Guid.NewGuid(), this.cache, this.uri); var iteration = new Iteration(Guid.NewGuid(), this.cache, this.uri); - + model.Iteration.Add(iteration); - + var transactionContext = TransactionContextResolver.ResolveContext(iteration); var transaction = new ThingTransaction(transactionContext); @@ -1067,9 +1071,9 @@ public void VerifyThatGetLastCloneCreatedThrowsExceptionWhenThingIsNullOrGuidIsE [Test] public void VerifyThatArgumentNullExceptionIsThrownWhenContextIsNull() { - Assert.Throws(() => new ThingTransaction(null)); + Assert.Throws(() => new ThingTransaction(null)); } - + [Test] public void VerifyThatArgumentNullExceptionIsThrownWhenCloneIsNull() { @@ -1085,7 +1089,7 @@ public void VerifyThatArgumentNullExceptionIsThrownWhenCloneIsNull() var iterationClone = iteration.Clone(false); var elementDefinitionClone = elementDefinition.Clone(false); - Assert.Throws(() => new ThingTransaction(null, null, iterationClone)); + Assert.Throws(() => new ThingTransaction(null, null, iterationClone)); } } } diff --git a/CDP4Dal.Tests/SessionTestFixture.cs b/CDP4Dal.Tests/SessionTestFixture.cs index 6b6b45adf..07b0316fb 100644 --- a/CDP4Dal.Tests/SessionTestFixture.cs +++ b/CDP4Dal.Tests/SessionTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Tests { @@ -37,12 +37,12 @@ namespace CDP4Dal.Tests using CDP4Common.Types; using CDP4Dal.Composition; - using CDP4Dal.Operations; using CDP4Dal.DAL; using CDP4Dal.Events; using CDP4Dal.Exceptions; + using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Tasks; using Moq; @@ -130,10 +130,7 @@ public void TearDown() public async Task VerifythatOpenCallAssemblerSynchronizeWithDtos() { var eventReceived = false; - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); await this.session.Open(); @@ -178,10 +175,7 @@ public void VerifyThatOpenCallMightBeCancelled() })); } - Assert.DoesNotThrowAsync(async () => - { - await Task.WhenAll(tasks.ToArray()); - }); + Assert.DoesNotThrowAsync(async () => { await Task.WhenAll(tasks.ToArray()); }); } [Test] @@ -196,18 +190,18 @@ public async Task VerifyThatWriteWithEmptyResponseSendsMessages() this.messageBus.Listen() .Subscribe(x => - { - if (x.Status == SessionStatus.BeginUpdate) { - beginUpdateReceived = true; - return; - } + if (x.Status == SessionStatus.BeginUpdate) + { + beginUpdateReceived = true; + return; + } - if (x.Status == SessionStatus.EndUpdate) - { - endUpdateReceived = true; - } - }); + if (x.Status == SessionStatus.EndUpdate) + { + endUpdateReceived = true; + } + }); var context = $"/SiteDirectory/{Guid.NewGuid()}"; @@ -234,10 +228,7 @@ public async Task VerifythatRefreshSynchronizeTheAssembler() await this.session.Open(); - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); // refresh shouldnt do anything await this.session.Refresh(); @@ -267,10 +258,7 @@ public async Task VerifythatReloadSynchronizeTheAssembler() await this.session.Open(); - this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => - { - eventReceived = true; - }); + this.messageBus.Listen(typeof(TelephoneNumber)).Subscribe(x => { eventReceived = true; }); await this.session.Reload(); @@ -364,7 +352,7 @@ public async Task VerifyThatCloseRdlWorks() session.Assembler.Cache.TryGetValue(new CacheKey(rdlPoco.Iid, null), out rdlPocoToClose); await session.CloseRdl((CDP4Common.SiteDirectoryData.SiteReferenceDataLibrary)rdlPocoToClose.Value); Assert.AreEqual(1, session.OpenReferenceDataLibraries.ToList().Count); - + await session.Read(rdlPoco); Assert.AreEqual(2, session.OpenReferenceDataLibraries.ToList().Count); @@ -467,14 +455,15 @@ public async Task VerifyThatSiteRdlRequiredByModelRdlCannotBeClosed() var participant = new CDP4Common.DTO.Participant(Guid.NewGuid(), 0) { Person = this.person.Iid }; modelsetup.Participant.Add(participant.Iid); - var modelPoco = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null){EngineeringModelSetup = modelsetuppoco}; + var modelPoco = new CDP4Common.EngineeringModelData.EngineeringModel(model.Iid, null, null) { EngineeringModelSetup = modelsetuppoco }; var iterationPoco = new CDP4Common.EngineeringModelData.Iteration(iteration.Iid, null, null); modelPoco.Iteration.Add(iterationPoco); var readTaskCompletionSource = new TaskCompletionSource>(); readTaskCompletionSource.SetResult(readReturn); + this.mockedDal.Setup( - x => x.Read(It.IsAny(), It.IsAny(), null)) + x => x.Read(It.IsAny(), It.IsAny(), null)) .Returns(readTaskCompletionSource.Task); var thingsToAdd = new List() { siteDirDto, requiredRdlDto, rdlDto, this.person, participant, modelsetup }; @@ -568,6 +557,7 @@ public async Task VerifyThatReadRdlWorks() { var siteDir = new CDP4Common.SiteDirectoryData.SiteDirectory(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; + this.session.Assembler.Cache.TryAdd(new CacheKey(siteDir.Iid, null), new Lazy(() => siteDir)); @@ -599,7 +589,7 @@ public async Task VerifyThatReadRdlWorks() public async Task VerifyThatReadIterationWorks() { var siteDir = new CDP4Common.SiteDirectoryData.SiteDirectory(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); - var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) {ShortName = "John"}; + var JohnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; var modelSetup = new CDP4Common.SiteDirectoryData.EngineeringModelSetup(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); var iterationSetup = new CDP4Common.SiteDirectoryData.IterationSetup(Guid.NewGuid(), this.session.Assembler.Cache, this.uri) { FrozenOn = DateTime.Now, IterationIid = Guid.NewGuid() }; var mrdl = new ModelReferenceDataLibrary(Guid.NewGuid(), this.session.Assembler.Cache, this.uri); @@ -738,10 +728,7 @@ public async Task VerifyThatWriteWorksWithEventHandler() var johnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; this.session.GetType().GetProperty("ActivePerson")?.SetValue(this.session, johnDoe, null); - this.session.BeforeWrite += (o, args) => - { - args.Cancelled = false; - }; + this.session.BeforeWrite += (o, args) => { args.Cancelled = false; }; await this.session.Write(new OperationContainer(context)); @@ -755,10 +742,7 @@ public void VerifyThatCancelWriteWorks() var johnDoe = new CDP4Common.SiteDirectoryData.Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; this.session.GetType().GetProperty("ActivePerson")?.SetValue(this.session, johnDoe, null); - this.session.BeforeWrite += (o, args) => - { - args.Cancelled = true; - }; + this.session.BeforeWrite += (o, args) => { args.Cancelled = true; }; Assert.ThrowsAsync(async () => await this.session.Write(new OperationContainer(context))); @@ -784,11 +768,11 @@ public async Task VerifyCanCherryPick() categoriesId.Add(Guid.NewGuid()); var elementDefinitionId = Guid.NewGuid(); - cherryPickedThings.Add(new Iteration(){Iid = engineeringModelId, Element = new List{elementDefinitionId}}); - cherryPickedThings.Add(new ElementDefinition(){Iid = elementDefinitionId, Category = new List { categoriesId[0] }}); + cherryPickedThings.Add(new Iteration() { Iid = engineeringModelId, Element = new List { elementDefinitionId } }); + cherryPickedThings.Add(new ElementDefinition() { Iid = elementDefinitionId, Category = new List { categoriesId[0] } }); readThings = (await this.session.CherryPick(engineeringModelId, iterationId, classKinds, categoriesId)).ToList(); - + Assert.Multiple(() => { Assert.That(readThings, Is.Not.Empty); @@ -893,7 +877,7 @@ public async Task VerifyWritePossibleLongRunningTask() this.mockedDal.Setup(x => x.Write(It.IsAny(), It.IsAny(), It.IsAny>())) .ReturnsAsync(new LongRunningTaskResult(new CometTask() { Id = Guid.Empty })); - + var cometTask = await this.session.Write(new OperationContainer(context), 1); Assert.Multiple(() => @@ -922,8 +906,9 @@ public async Task VerifyWritePossibleLongRunningTask() this.mockedDal.Setup(x => x.Write(It.IsAny(), It.IsAny(), It.IsAny>())) .ThrowsAsync(new DalReadException()); - Assert.That(() =>this.session.Write(new OperationContainer(context), 1), Throws.Exception.TypeOf()); + Assert.That(() => this.session.Write(new OperationContainer(context), 1), Throws.Exception.TypeOf()); } + private void AssignActivePerson() { var johnDoe = new Person(this.person.Iid, this.session.Assembler.Cache, this.uri) { ShortName = "John" }; @@ -934,16 +919,30 @@ private void AssignActivePerson() [DalExport("test dal", "test dal description", "1.1.0", DalType.Web)] internal class TestDal : IDal { - public Version SupportedVersion { get {return new Version(1, 0, 0);} } - public Version DalVersion { get {return new Version("1.1.0");} } - public IMetaDataProvider MetaDataProvider { get {return new MetaDataProvider();} } + public Version SupportedVersion + { + get { return new Version(1, 0, 0); } + } + + public Version DalVersion + { + get { return new Version("1.1.0"); } + } + + public IMetaDataProvider MetaDataProvider + { + get { return new MetaDataProvider(); } + } /// /// Gets or sets the that uses this /// public ISession Session { get; set; } - public bool IsReadOnly { get { return false; } } + public bool IsReadOnly + { + get { return false; } + } /// /// Write all the s from all the s asynchronously. @@ -1184,4 +1183,4 @@ public Task> CherryPick(Guid engineeringModelId, Guid iterati throw new NotImplementedException(); } } -} \ No newline at end of file +} diff --git a/CDP4Dal/DAL/Dal.cs b/CDP4Dal/DAL/Dal.cs index 578de2fb5..425bf12ed 100644 --- a/CDP4Dal/DAL/Dal.cs +++ b/CDP4Dal/DAL/Dal.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of COMET-SDK Community Edition -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.DAL { @@ -36,15 +36,16 @@ namespace CDP4Dal.DAL using CDP4Common.DTO; using CDP4Common.Helpers; using CDP4Common.MetaInfo; - - using CDP4Dal.Operations; + using CDP4Dal.Composition; using CDP4Dal.Exceptions; + using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using NLog; - + using Iteration = CDP4Common.DTO.Iteration; using Thing = CDP4Common.DTO.Thing; @@ -217,7 +218,7 @@ protected Dal() /// The /// /// an await-able that returns a array. - public abstract Task ReadFile(Thing thing, CancellationToken cancellationToken) ; + public abstract Task ReadFile(Thing thing, CancellationToken cancellationToken); /// /// Creates the specified on a data source @@ -438,7 +439,7 @@ public bool TryExtractIterationIdfromUri(Uri uri, out Guid iterationId) } catch (Exception ex) { - Logger.Warn(ex,"The Iteration identifier could not be exracted from {0}", uri); + Logger.Warn(ex, "The Iteration identifier could not be exracted from {0}", uri); iterationId = Guid.Empty; return false; @@ -543,4 +544,4 @@ protected virtual void SetCdpVersion() } } } -} \ No newline at end of file +} diff --git a/CDP4Dal/DAL/IDal.cs b/CDP4Dal/DAL/IDal.cs index 368491b71..179a49356 100644 --- a/CDP4Dal/DAL/IDal.cs +++ b/CDP4Dal/DAL/IDal.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.DAL { @@ -35,7 +35,8 @@ namespace CDP4Dal.DAL using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using Thing = CDP4Common.DTO.Thing; @@ -63,7 +64,7 @@ public interface IDal /// Gets the value indicating whether this is read only /// bool IsReadOnly { get; } - + /// /// Write all the s from all the s asynchronously. /// @@ -91,7 +92,7 @@ public interface IDal /// A list of s that has been created or updated since the last Read or Write operation. /// Task> Write(OperationContainer operationContainer, IEnumerable files = null); - + /// /// Write all the s from an asynchronously for a possible long running task. /// @@ -276,7 +277,7 @@ public interface IDal /// A collection of s /// The /// A of type of read - Task> CherryPick(Guid engineeringModelId, Guid iterationId, IEnumerable classKinds, + Task> CherryPick(Guid engineeringModelId, Guid iterationId, IEnumerable classKinds, IEnumerable categoriesId, CancellationToken cancellationToken); } -} \ No newline at end of file +} diff --git a/CDP4Dal/Exceptions/InvalidOperationContainerException.cs b/CDP4Dal/Exceptions/InvalidOperationContainerException.cs index 5b245e8b4..4296520e1 100644 --- a/CDP4Dal/Exceptions/InvalidOperationContainerException.cs +++ b/CDP4Dal/Exceptions/InvalidOperationContainerException.cs @@ -1,21 +1,21 @@ // ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexandervan Delft, Nathanael Smiechowski, Ahmed Abulwafa Ahmed -// -// This file is part of COMET-SDK Community Edition -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -29,6 +29,8 @@ namespace CDP4Dal.Exceptions using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + /// /// A is thrown when an is invalid or incomplete, /// or one of the contained s is invalid or incomplete. diff --git a/CDP4Dal/Exceptions/InvalidOperationKindException.cs b/CDP4Dal/Exceptions/InvalidOperationKindException.cs index b25a089ba..bad5c8d8b 100644 --- a/CDP4Dal/Exceptions/InvalidOperationKindException.cs +++ b/CDP4Dal/Exceptions/InvalidOperationKindException.cs @@ -1,21 +1,21 @@ // ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexandervan Delft, Nathanael Smiechowski, Ahmed Abulwafa Ahmed -// -// This file is part of COMET-SDK Community Edition -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -29,9 +29,11 @@ namespace CDP4Dal.Exceptions using CDP4Dal.DAL; + using CDP4DalCommon.Protocol.Operations; + /// /// A InvalidOperationKindException is thrown whenever an contains - /// that are not supported by the implementation of an + /// that are not supported by the implementation of an /// [Serializable] public class InvalidOperationKindException : Exception diff --git a/CDP4Dal/ISession.cs b/CDP4Dal/ISession.cs index 75213100e..b89e6486b 100644 --- a/CDP4Dal/ISession.cs +++ b/CDP4Dal/ISession.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal { @@ -33,13 +33,13 @@ namespace CDP4Dal using CDP4Common.EngineeringModelData; using CDP4Common.SiteDirectoryData; - using CDP4Dal.Operations; using CDP4Dal.DAL; using CDP4Dal.Events; + using CDP4Dal.Operations; + using CDP4Dal.Permission; - using CDP4DalCommon.Tasks; - - using Permission; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; /// /// The interface encapsulates an and @@ -55,7 +55,7 @@ public interface ISession /// /// Gets the that are use to connect to the data source /// - Credentials Credentials { get; } + Credentials Credentials { get; } /// /// Gets all the s that the active person is linked with. @@ -106,7 +106,7 @@ public interface ISession /// /// Gets the name of the session which is the concatentation of the data-source uri and the active person /// - string Name { get; } + string Name { get; } /// /// Gets the list of that are currently open in the running application. @@ -116,7 +116,7 @@ public interface ISession /// /// Gets the list of s that are currently open with the active and /// - IReadOnlyDictionary > OpenIterations { get; } + IReadOnlyDictionary> OpenIterations { get; } /// /// Gets the that handles messaging for this session diff --git a/CDP4Dal/Operations/IThingTransaction.cs b/CDP4Dal/Operations/IThingTransaction.cs index f979f8ddd..664098d16 100644 --- a/CDP4Dal/Operations/IThingTransaction.cs +++ b/CDP4Dal/Operations/IThingTransaction.cs @@ -1,35 +1,38 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Operations { using System; using System.Collections.Generic; + using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.Types; + using CDP4DalCommon.Protocol.Operations; + /// /// The interface operations /// @@ -190,4 +193,4 @@ public interface IThingTransaction /// The sub- void Merge(IThingTransaction subTransaction); } -} \ No newline at end of file +} diff --git a/CDP4Dal/Operations/LongRunningTaskResult.cs b/CDP4Dal/Operations/LongRunningTaskResult.cs index b493cb5c4..c0b4f7d5a 100644 --- a/CDP4Dal/Operations/LongRunningTaskResult.cs +++ b/CDP4Dal/Operations/LongRunningTaskResult.cs @@ -2,7 +2,7 @@ // // Copyright (c) 2015-2024 RHEA System S.A. // -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -28,7 +28,7 @@ namespace CDP4Dal.Operations using CDP4Common.DTO; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Tasks; /// /// Handle the returned data of a possible long running task diff --git a/CDP4Dal/Operations/OperationContainer.cs b/CDP4Dal/Operations/OperationContainer.cs index e6b2e64ba..2b66a7a9b 100644 --- a/CDP4Dal/Operations/OperationContainer.cs +++ b/CDP4Dal/Operations/OperationContainer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Operations { @@ -30,6 +30,8 @@ namespace CDP4Dal.Operations using CDP4Common.DTO; using CDP4Common.Helpers; + using CDP4DalCommon.Protocol.Operations; + /// /// A container for the s that need to be executed on a data source using an implementation of /// @@ -62,7 +64,7 @@ public OperationContainer(string context, int? topContainerRevNumber = null) this.Token = TokenGenerator.GenerateRandomToken(); this.Context = context; - + this.operations = new List(); this.TopContainerRevisionNumber = topContainerRevNumber; } @@ -94,10 +96,7 @@ public OperationContainer(string context, int? topContainerRevNumber = null) /// public IEnumerable Operations { - get - { - return this.operations; - } + get { return this.operations; } } /// @@ -136,7 +135,7 @@ private void ValidateContextOfOperation(Operation operation) /// public void RemoveOperation(Operation operation) { - this.operations.Remove(operation); + this.operations.Remove(operation); } } -} \ No newline at end of file +} diff --git a/CDP4Dal/Operations/OperationKindExtensions.cs b/CDP4Dal/Operations/OperationKindExtensions.cs index a646933fc..f3b75c509 100644 --- a/CDP4Dal/Operations/OperationKindExtensions.cs +++ b/CDP4Dal/Operations/OperationKindExtensions.cs @@ -1,31 +1,33 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Nathanael Smiechowski -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Operations { using CDP4Common.DTO; + using CDP4DalCommon.Protocol.Operations; + /// /// Utils class to provide OperationKind Extensions to CDP4Dal /// diff --git a/CDP4Dal/Operations/ThingTransaction.cs b/CDP4Dal/Operations/ThingTransaction.cs index 2a12d04c0..8b74fb5c0 100644 --- a/CDP4Dal/Operations/ThingTransaction.cs +++ b/CDP4Dal/Operations/ThingTransaction.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details.copy -// +// Lesser General Public License for more details. +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal.Operations { @@ -31,15 +31,17 @@ namespace CDP4Dal.Operations using System.Reflection; using CDP4Common; + using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.Extensions; using CDP4Common.Polyfills; using CDP4Common.SiteDirectoryData; - using CDP4Common.CommonData; using CDP4Common.Types; using CDP4Dal.Exceptions; + using CDP4DalCommon.Protocol.Operations; + using NLog; /// @@ -92,10 +94,10 @@ public class ThingTransaction : IThingTransaction /// public ThingTransaction(TransactionContext transactionContext, Thing clone = null) { - this.TransactionContext = - transactionContext ?? + this.TransactionContext = + transactionContext ?? throw new ArgumentNullException(nameof(transactionContext), $"The {nameof(transactionContext)} may not be null"); - + this.addedThing = new List(); this.updatedThing = new Dictionary(); this.deletedThing = new List(); @@ -137,7 +139,7 @@ public ThingTransaction(Thing clone, IThingTransaction parentTransaction, Thing { throw new ArgumentNullException(nameof(clone), $"The {nameof(clone)} may not be null."); } - + this.TransactionContext = parentTransaction.TransactionContext; this.addedThing = new List(); @@ -299,18 +301,19 @@ public void CreateOrUpdate(Thing clone) throw new ArgumentNullException(nameof(clone), $"The {nameof(clone)} may not be null"); } - if(this.UpdatedThing.Values.Any(x => x == clone) || this.AddedThing.Any(x => x == clone)) + if (this.UpdatedThing.Values.Any(x => x == clone) || this.AddedThing.Any(x => x == clone)) { return; } - if(this.UpdatedThing.Values.Any(x => x.Iid == clone.Iid) || this.AddedThing.Any(x => x.Iid == clone.Iid)) + if (this.UpdatedThing.Values.Any(x => x.Iid == clone.Iid) || this.AddedThing.Any(x => x.Iid == clone.Iid)) { return; } var UpdatedThing = this.GetUpdatedThing(clone); - if(UpdatedThing != null) + + if (UpdatedThing != null) { if (clone.Iid == Guid.Empty) { @@ -337,7 +340,7 @@ public void Delete(Thing clone, Thing containerClone = null) { throw new ArgumentNullException(nameof(clone), $"The {nameof(clone)} may not be null."); } - + if (this.DeletedThing.Any(x => x.Iid == clone.Iid)) { return; @@ -363,6 +366,7 @@ public void Delete(Thing clone, Thing containerClone = null) { // remove potential reference from the list of updated thing in the current transaction var updatedThingKey = this.UpdatedThing.Keys.SingleOrDefault(x => x.Iid == clone.Iid); + if (updatedThingKey != null) { this.updatedThing.Remove(updatedThingKey); @@ -375,6 +379,7 @@ public void Delete(Thing clone, Thing containerClone = null) { // remove from the list of added thing var thingInAddedList = this.AddedThing.SingleOrDefault(x => x.Iid == clone.Iid); + if (thingInAddedList != null) { this.addedThing.Remove(thingInAddedList); @@ -434,7 +439,7 @@ public void Copy(Thing clone, OperationKind operationKind) { throw new ArgumentException("The copy operation may only be performed with Copy or CopyDefaultValuesChangeOwner or CopyKeepValues or CopyKeepValuesChangeOwner", nameof(operationKind)); } - + var original = this.GetUpdatedThing(clone); // setting a new iid for the copy @@ -445,7 +450,7 @@ public void Copy(Thing clone, OperationKind operationKind) { return; } - + // setting a new iid for the copy clone.Iid = Guid.NewGuid(); this.copiedThing.Add(originalCopyPair, operationKind); @@ -469,13 +474,14 @@ public Thing GetClone(Thing thing) } var clone = this.UpdatedThing.Values.SingleOrDefault(x => x.Iid == thing.Iid); + if (clone != null) { return clone; } clone = this.AddedThing.SingleOrDefault(x => x.Iid == thing.Iid); - + return clone; } @@ -498,6 +504,7 @@ public Thing GetLastCloneCreated(Thing thing) var allAddedThing = this.GetAllAddedThings().ToList(); var clone = allAddedThing.SingleOrDefault(x => x.Iid == thing.Iid); + if (clone != null) { return clone; @@ -505,7 +512,7 @@ public Thing GetLastCloneCreated(Thing thing) var allUpdatedThing = this.GetAllUpdatedThings().ToList(); clone = allUpdatedThing.SingleOrDefault(x => x.Iid == thing.Iid); - + return clone; } @@ -549,8 +556,8 @@ public void FinalizeSubTransaction(Thing clone, Thing containerclone, Thing next foreach ( var addedThing in - this.AddedThing.Where( - x => x != this.AssociatedClone && x.GetContainerInformation().Item1 == cloneTypeToUpdate)) + this.AddedThing.Where( + x => x != this.AssociatedClone && x.GetContainerInformation().Item1 == cloneTypeToUpdate)) { if (!addedThing.IsContainedBy(rootClone.Iid)) { @@ -560,6 +567,7 @@ var addedThing in // the clone should have been added var containerOfAddedThing = this.GetClone(addedThing.Container); + if (containerOfAddedThing == null) { throw new TransactionException("could not find the corresponding clone for the container of the added thing added outside the chain of transaction."); @@ -570,8 +578,8 @@ var addedThing in foreach ( var updatedThing in - this.UpdatedThing.Values.Where( - x => x != this.AssociatedClone && x.GetContainerInformation().Item1 == cloneTypeToUpdate)) + this.UpdatedThing.Values.Where( + x => x != this.AssociatedClone && x.GetContainerInformation().Item1 == cloneTypeToUpdate)) { if (!updatedThing.IsContainedBy(rootClone.Iid)) { @@ -581,6 +589,7 @@ var updatedThing in // the clone should have been added var containerOfUpdatedThing = this.GetClone(updatedThing.Container); + if (containerOfUpdatedThing == null) { throw new TransactionException( @@ -605,7 +614,7 @@ public OperationContainer FinalizeTransaction() } this.FilterOperationCausedByDelete(); - + var context = this.TransactionContext.ContextRoute(); var operationContainer = new OperationContainer(context, this.GetTopContainerRevisionNumber()); @@ -629,7 +638,7 @@ public string[] GetFiles() { if (string.IsNullOrWhiteSpace(thing.ContentHash)) { - throw new InvalidOperationException($"File {thing.LocalPath} cannot be saved because of an empty ContentHash" ); + throw new InvalidOperationException($"File {thing.LocalPath} cannot be saved because of an empty ContentHash"); } files.Add(thing.LocalPath); @@ -649,7 +658,8 @@ private Thing GetUpdatedThing(Thing clone) var allUpdatedThings = this.GetAllUpdatedThings().ToList(); var updatedThing = allUpdatedThings.SingleOrDefault(x => x.Iid == clone.Iid); - if(updatedThing != null) + + if (updatedThing != null) { if (updatedThing == clone) { @@ -662,6 +672,7 @@ private Thing GetUpdatedThing(Thing clone) // case2: the updated thing is already in the transaction as an added thing var allAddedThings = this.GetAllAddedThings().ToList(); updatedThing = allAddedThings.SingleOrDefault(x => x.Iid == clone.Iid); + if (updatedThing != null) { if (updatedThing == clone) @@ -681,6 +692,7 @@ private Thing GetUpdatedThing(Thing clone) // case3: the cache does not contain the key, its a new var lazy = clone.Cache.SingleOrDefault(x => Equals(x.Key, clone.CacheKey)).Value; + if (lazy == null) { return null; @@ -688,6 +700,7 @@ private Thing GetUpdatedThing(Thing clone) // case4: the updated thing is the original updatedThing = lazy.Value; + if (updatedThing == clone) { throw new InvalidOperationException("The transaction only accepts clones."); @@ -703,6 +716,7 @@ private Thing GetUpdatedThing(Thing clone) private IEnumerable GetAllAddedThings() { var allAddedThing = this.AddedThing.ToList(); + if (this.ParentTransaction != null) { this.PopulateAllAddedThingsList(this.ParentTransaction, allAddedThing); @@ -720,6 +734,7 @@ private void PopulateAllAddedThingsList(IThingTransaction transaction, List allAddedThing.All(y => y.Iid != x.Iid)); allAddedThing.AddRange(thingsToAdd); + if (transaction.ParentTransaction != null) { this.PopulateAllAddedThingsList(transaction.ParentTransaction, allAddedThing); @@ -733,6 +748,7 @@ private void PopulateAllAddedThingsList(IThingTransaction transaction, List GetAllUpdatedThings() { var allUpdatedThings = this.UpdatedThing.Values.ToList(); + if (this.ParentTransaction != null) { this.PopulateAllUpdatedThingsList(this.ParentTransaction, allUpdatedThings); @@ -750,6 +766,7 @@ private void PopulateAllUpdatedThingsList(IThingTransaction transaction, List allUpdatedThing.All(y => y.Iid != x.Iid)); allUpdatedThing.AddRange(thingsToAdd); + if (transaction.ParentTransaction != null) { this.PopulateAllUpdatedThingsList(transaction.ParentTransaction, allUpdatedThing); @@ -765,14 +782,15 @@ private void PopulateAllUpdatedThingsList(IThingTransaction transaction, List) }); + var findIndexMethod = containerProperty.PropertyType.GetMethod("FindIndex", new[] { typeof(Predicate) }); Predicate predicate = x => x.Iid == thing.Iid; - var index = (int)(findIndexMethod?.Invoke(containerList, new object[] { predicate })??-1); + var index = (int)(findIndexMethod?.Invoke(containerList, new object[] { predicate }) ?? -1); + if (index != -1) { // Get the indexer property, by default the indexer property name is "Item" @@ -809,6 +827,7 @@ private void UpdateOrderedItemList(Thing thing, Thing containerClone, Thing next Predicate predicate = x => x.Iid == thing.Iid; var index = (int)findIndexMethod.Invoke(containerList, new object[] { predicate }); + if (index != -1) { // Get the indexer property, by default the indexer property name is "Item" @@ -822,7 +841,7 @@ private void UpdateOrderedItemList(Thing thing, Thing containerClone, Thing next { // normal add var addMethod = orderedListProperty.PropertyType.GetMethod("Add"); - addMethod.Invoke(containerList, new object[] {thing}); + addMethod.Invoke(containerList, new object[] { thing }); } else { @@ -830,6 +849,7 @@ private void UpdateOrderedItemList(Thing thing, Thing containerClone, Thing next var indexOfMethod = orderedListProperty.PropertyType.GetMethod("IndexOf"); var index = indexOfMethod.Invoke(containerList, new object[] { nextThing }) as int?; + if (index == -1 || !index.HasValue) { throw new InvalidOperationException("The Thing before which the new item needs to be inserted does not exist."); @@ -850,14 +870,15 @@ private void UpdateOrderedItemList(Thing thing, Thing containerClone, Thing next private void RemoveThingFromContainer(Thing thing) { var containers = this.AddedThing.Concat(this.UpdatedThing.Values); - + var thingType = thing.GetType(); Thing originalThing = null; + if (thing.Cache != null && thing.Cache.ContainsKey(thing.CacheKey)) { var result = thing.Cache.TryGetValue(thing.CacheKey, out var lazyThing); - originalThing = (result)? lazyThing.Value : null; + originalThing = (result) ? lazyThing.Value : null; } // Find in all the thing in the transaction the potential container that contains the current thing @@ -877,7 +898,7 @@ private void RemoveThingFromContainer(Thing thing) var matchingPropertyInfos = containerType.GetProperties().Where(x => x.PropertyType.QueryIsGenericType() && (x.PropertyType.GetGenericTypeDefinition() == typeof(ContainerList<>) || - x.PropertyType.GetGenericTypeDefinition() == typeof(OrderedItemList<>)) && + x.PropertyType.GetGenericTypeDefinition() == typeof(OrderedItemList<>)) && x.PropertyType.GetGenericArguments().Single().QueryIsAssignableFrom(thingType)).ToList(); foreach (var propertyInfo in matchingPropertyInfos) @@ -886,6 +907,7 @@ private void RemoveThingFromContainer(Thing thing) var containerList = propertyInfo.GetValue(container) as IEnumerable; Thing thingToRemove = null; + foreach (Thing containedThing in containerList) { if (containedThing.Iid == thing.Iid) @@ -900,6 +922,7 @@ private void RemoveThingFromContainer(Thing thing) } var success = (bool)removeMethod.Invoke(containerList, new object[] { thingToRemove }); + if (success) { thingToRemove.Container = null; @@ -921,6 +944,7 @@ private void InitializeSubTransaction(ThingTransaction subTransaction, Thing con if (containerClone != null) { var currentContainertype = containerClone.GetType(); + if (!containerType.QueryIsAssignableFrom(currentContainertype)) { throw new InvalidOperationException("The specified container is not allowed as a container."); @@ -949,6 +973,7 @@ private void InitializeSubTransaction(ThingTransaction subTransaction, Thing con private void AddChainOfContainers(Thing clone) { var topOperationClone = this.GetOperationRootClone(); + if (!clone.IsContainedBy(topOperationClone.Iid)) { return; @@ -972,6 +997,7 @@ private void AddChainOfContainers(Thing clone) // add a new clone if newContainerClone is not contained by the current operation's chain of clones var containerType = transaction.AssociatedClone.GetType(); var container = clone.GetContainerOfType(containerType); + if (container == null) { return; @@ -992,6 +1018,7 @@ private Thing GetOperationRootClone() { var rootClone = this.AssociatedClone; var parent = this.ParentTransaction; + while (parent != null) { rootClone = parent.AssociatedClone ?? rootClone; @@ -1008,9 +1035,11 @@ private Thing GetOperationRootClone() private IEnumerable GetChainOfSubTransactions() { var parent = this.ParentTransaction; + while (parent != null) { yield return parent; + parent = parent.ParentTransaction; } } @@ -1027,6 +1056,7 @@ private IEnumerable GetChainOfSubTransactions() private void UpdateContainer(Thing clone, Thing containerclone, Thing nextThing = null) { var containerInformation = clone.GetContainerInformation(); + if (!containerInformation.Item1.IsInstanceOfType(containerclone)) { throw new InvalidOperationException("The containerClone does not have the right type"); @@ -1055,6 +1085,7 @@ private void UpdateContainer(Thing clone, Thing containerclone, Thing nextThing private void AddCloneToContainer(Thing clone, Thing containerclone, Thing nextThing = null) { var containerInformation = clone.GetContainerInformation(); + if (!containerInformation.Item1.IsInstanceOfType(containerclone)) { throw new InvalidOperationException("The containerClone does not have the right type"); @@ -1095,6 +1126,7 @@ public void Merge(IThingTransaction subTransaction) } var existingThing = this.AddedThing.SingleOrDefault(t => t.Iid == thing.Iid); + if (existingThing != null) { // replace the current thing with the one from the sub-transaction @@ -1112,6 +1144,7 @@ public void Merge(IThingTransaction subTransaction) if (this.UpdatedThing.ContainsKey(keyValuePair.Key)) { var parentKeyValue = this.UpdatedThing.Single(x => x.Key == keyValuePair.Key); + if (parentKeyValue.Value != keyValuePair.Value) { throw new InvalidOperationException("2 clones have been created for the same thing."); @@ -1122,6 +1155,7 @@ public void Merge(IThingTransaction subTransaction) // check if the key in a sub-transaction correspond to a value in the current one var existingKeyValue = this.UpdatedThing.SingleOrDefault(x => x.Value == keyValuePair.Key); + if (existingKeyValue.Key != null) { this.updatedThing[existingKeyValue.Key] = keyValuePair.Value; @@ -1249,7 +1283,7 @@ private void CreateCopyThingOperation(OperationContainer operationContainer) if (copyOperationKind.IsCopyOperation()) { operationContainer.AddOperation(new Operation(original, copy, copyOperationKind)); - } + } } } @@ -1273,7 +1307,8 @@ private int GetTopContainerRevisionNumber() things.AddRange(this.DeletedThing); things.AddRange(this.CopiedThing.Select(x => x.Key.Item2)); - var distinctTopContainer = things.Select(x => x.TopContainer).DistinctBy(t => t.Iid).ToList(); + var distinctTopContainer = things.Select(x => x.TopContainer).DistinctBy(t => t.Iid).ToList(); + if (distinctTopContainer.Count != 1) { throw new InvalidOperationException("multiple top container updates in one transaction, operation not allowed."); @@ -1290,18 +1325,21 @@ private void FilterOperationCausedByDelete() // filter out the added thing or updated thing that have been marked as deleted // filter out the contained thing of a deleted thing var markedForDeletion = this.DeletedThing.ToList(); + foreach (var thing in markedForDeletion) { var cloneType = thing.GetType(); + var containersInfo = cloneType.GetProperties().Where(x => - x.PropertyType.QueryIsGenericType() && - (x.PropertyType.GetGenericTypeDefinition() == typeof(ContainerList<>) || - x.PropertyType.GetGenericTypeDefinition() == typeof(OrderedItemList<>)) && - typeof(Thing).QueryIsAssignableFrom(x.PropertyType.GetGenericArguments().Single())).ToList(); + x.PropertyType.QueryIsGenericType() && + (x.PropertyType.GetGenericTypeDefinition() == typeof(ContainerList<>) || + x.PropertyType.GetGenericTypeDefinition() == typeof(OrderedItemList<>)) && + typeof(Thing).QueryIsAssignableFrom(x.PropertyType.GetGenericArguments().Single())).ToList(); foreach (var containerInfo in containersInfo) { var container = (IEnumerable)containerInfo.GetValue(thing); + foreach (Thing containedThing in container) { this.RemoveThingFromOperationLists(containedThing); @@ -1320,6 +1358,7 @@ private void RemoveThingFromOperationLists(Thing thingToRemove) { // remove it from the list of updated thing in the current transaction var updatedThingKey = this.UpdatedThing.Keys.SingleOrDefault(x => x.Iid == thingToRemove.Iid); + if (updatedThingKey != null) { this.updatedThing.Remove(updatedThingKey); @@ -1327,6 +1366,7 @@ private void RemoveThingFromOperationLists(Thing thingToRemove) // remove from the list of added thing var thingInAddedList = this.AddedThing.SingleOrDefault(x => x.Iid == thingToRemove.Iid); + if (thingInAddedList != null) { this.addedThing.Remove(thingInAddedList); @@ -1336,6 +1376,7 @@ private void RemoveThingFromOperationLists(Thing thingToRemove) if (!thingToRemove.IsCached()) { var thingInDeletedList = this.DeletedThing.SingleOrDefault(x => x.Iid == thingToRemove.Iid); + if (thingInDeletedList != null) { this.deletedThing.Remove(thingInDeletedList); @@ -1343,4 +1384,4 @@ private void RemoveThingFromOperationLists(Thing thingToRemove) } } } -} \ No newline at end of file +} diff --git a/CDP4Dal/Session.cs b/CDP4Dal/Session.cs index 302bb5b17..f81da80a2 100644 --- a/CDP4Dal/Session.cs +++ b/CDP4Dal/Session.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4Dal { @@ -47,7 +47,8 @@ namespace CDP4Dal using CDP4Dal.Operations; using CDP4Dal.Permission; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using NLog; @@ -494,7 +495,7 @@ public async Task Read(ReferenceDataLibrary rdl) throw new InvalidOperationException("The ReferenceDataLibrary cannot be read when the ActivePerson is null; The Open method must be called prior to any of the Read methods"); } - await this.Read((Thing) rdl); + await this.Read((Thing)rdl); this.AddRdlToOpenList(rdl); } @@ -524,7 +525,7 @@ public async Task Read(IEnumerable engineeringModels) } logger.Info("Session.Read {EngineeringModel} {0}", !engineeringModels.Any() ? "*" : $"EngineeringModel/{engineeringModels.ToShortGuidArray()}"); - + // Create the token source var cancellationTokenSource = new CancellationTokenSource(); var cancellationTokenKey = Guid.NewGuid(); @@ -874,7 +875,7 @@ public Task Write(OperationContainer operationContainer) { var filesList = this.BeforeDalWriteAndProcessFiles(operationContainer, files); var longRunningTaskResult = await this.Dal.Write(operationContainer, waitTime, filesList); - + if (longRunningTaskResult.IsWaitTimeReached) { this.cometTasks[longRunningTaskResult.Task.Id] = longRunningTaskResult.Task; @@ -1179,7 +1180,7 @@ private IEnumerable GetSiteDirectoryAndActiveIterations() .Select(x => x.Value.Value) .Where(x => x is SiteDirectory - || x is Iteration && ((Iteration) x).IterationSetup.FrozenOn == null && this.OpenIterations.ContainsKey((Iteration) x) + || x is Iteration && ((Iteration)x).IterationSetup.FrozenOn == null && this.OpenIterations.ContainsKey((Iteration)x) ) .ToList(); } @@ -1246,7 +1247,7 @@ private void AddIterationToOpenList(Guid iterationId, DomainOfExpertise activeDo return; } - var activeParticipant = ((EngineeringModel) iteration.Container).EngineeringModelSetup.Participant.SingleOrDefault(p => p.Person == this.ActivePerson); + var activeParticipant = ((EngineeringModel)iteration.Container).EngineeringModelSetup.Participant.SingleOrDefault(p => p.Person == this.ActivePerson); if (activeParticipant == null) { @@ -1255,7 +1256,7 @@ private void AddIterationToOpenList(Guid iterationId, DomainOfExpertise activeDo this.openIterations.Add(iteration, new Tuple(activeDomain, activeParticipant)); - var modelRdl = ((EngineeringModel) iteration.Container).EngineeringModelSetup.RequiredRdl.Single(); + var modelRdl = ((EngineeringModel)iteration.Container).EngineeringModelSetup.RequiredRdl.Single(); this.AddRdlToOpenList(modelRdl); } diff --git a/CDP4Dal/Operations/Operation.cs b/CDP4DalCommon/Protocol/Operations/Operation.cs similarity index 79% rename from CDP4Dal/Operations/Operation.cs rename to CDP4DalCommon/Protocol/Operations/Operation.cs index 735cd1064..95fc49180 100644 --- a/CDP4Dal/Operations/Operation.cs +++ b/CDP4DalCommon/Protocol/Operations/Operation.cs @@ -1,68 +1,68 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public License -// along with this program; if not, write to the Free Software Foundation, -// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -// -------------------------------------------------------------------------------------------------------------------- - -namespace CDP4Dal.Operations -{ - using CDP4Common.DTO; - - /// - /// The change that is to be supplied to the data source via a Data-Access-Layer implementation - /// - public class Operation - { - /// - /// Initializes a new instance of the class. - /// - /// - /// The original fom the local domain store. - /// - /// - /// The modified - /// - /// - /// the kind of operation that is to be executed - /// - public Operation(Thing originalThing, Thing modifiedThing, OperationKind operationKind) - { - this.OriginalThing = originalThing; - this.ModifiedThing = modifiedThing; - this.OperationKind = operationKind; - } - - /// - /// Gets the kind of operation represented by this object. - /// - public OperationKind OperationKind { get; internal set; } - - /// - /// Gets the original that is the subject of the . - /// - public Thing OriginalThing { get; internal set; } - - /// - /// Gets the modified that is the subject of the . - /// - public Thing ModifiedThing { get; internal set; } - } -} +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalCommon.Protocol.Operations +{ + using CDP4Common.DTO; + + /// + /// The change that is to be supplied to the data source via a Data-Access-Layer implementation + /// + public class Operation + { + /// + /// Initializes a new instance of the class. + /// + /// + /// The original fom the local domain store. + /// + /// + /// The modified + /// + /// + /// the kind of operation that is to be executed + /// + public Operation(Thing originalThing, Thing modifiedThing, OperationKind operationKind) + { + this.OriginalThing = originalThing; + this.ModifiedThing = modifiedThing; + this.OperationKind = operationKind; + } + + /// + /// Gets the kind of operation represented by this object. + /// + public OperationKind OperationKind { get; internal set; } + + /// + /// Gets the original that is the subject of the . + /// + public Thing OriginalThing { get; internal set; } + + /// + /// Gets the modified that is the subject of the . + /// + public Thing ModifiedThing { get; internal set; } + } +} diff --git a/CDP4Dal/Operations/OperationKind.cs b/CDP4DalCommon/Protocol/Operations/OperationKind.cs similarity index 84% rename from CDP4Dal/Operations/OperationKind.cs rename to CDP4DalCommon/Protocol/Operations/OperationKind.cs index d4addde4b..d631bd5b0 100644 --- a/CDP4Dal/Operations/OperationKind.cs +++ b/CDP4DalCommon/Protocol/Operations/OperationKind.cs @@ -1,90 +1,90 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public License -// along with this program; if not, write to the Free Software Foundation, -// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -// -------------------------------------------------------------------------------------------------------------------- - -namespace CDP4Dal.Operations -{ - using CDP4Common.DTO; - - /// - /// The kind of acting on the object. - /// - public enum OperationKind - { - /// - /// specifies that the on the is a Create operation - /// - Create, - - /// - /// specifies that the on the is an Update operation - /// - Update, - - /// - /// specifies that the on the is a Delete operation - /// - Delete, - - /// - /// specifies that the on the is a Move operation - /// - Move, - - /// - /// specifies that the on the is a "shift" Copy operation - /// - /// - /// If are copied their value-sets shall contain default "-" values. - /// A copy shall keep its original owner - /// - Copy, - - /// - /// specifies that the on the is a "ctrl" Copy operation - /// - /// - /// If are copied their value-sets shall contain original values. - /// A copy shall have its owner set to the active one in the target destination. - /// - CopyKeepValuesChangeOwner, - - /// - /// specifies that the on the is a "dry" Copy operation - /// - /// - /// If are copied their value-sets shall contain default "-" values. - /// A copy shall have its owner set to the active one in the target destination. - /// - CopyDefaultValuesChangeOwner, - - /// - /// specifies that the on the is a "ctrl + shift" Copy operation - /// - /// - /// If are copied their value-sets shall contain the original values. - /// A copy shall keep its original owner - /// - CopyKeepValues - } -} \ No newline at end of file +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalCommon.Protocol.Operations +{ + using CDP4Common.DTO; + + /// + /// The kind of acting on the object. + /// + public enum OperationKind + { + /// + /// specifies that the on the is a Create operation + /// + Create, + + /// + /// specifies that the on the is an Update operation + /// + Update, + + /// + /// specifies that the on the is a Delete operation + /// + Delete, + + /// + /// specifies that the on the is a Move operation + /// + Move, + + /// + /// specifies that the on the is a "shift" Copy operation + /// + /// + /// If are copied their value-sets shall contain default "-" values. + /// A copy shall keep its original owner + /// + Copy, + + /// + /// specifies that the on the is a "ctrl" Copy operation + /// + /// + /// If are copied their value-sets shall contain original values. + /// A copy shall have its owner set to the active one in the target destination. + /// + CopyKeepValuesChangeOwner, + + /// + /// specifies that the on the is a "dry" Copy operation + /// + /// + /// If are copied their value-sets shall contain default "-" values. + /// A copy shall have its owner set to the active one in the target destination. + /// + CopyDefaultValuesChangeOwner, + + /// + /// specifies that the on the is a "ctrl + shift" Copy operation + /// + /// + /// If are copied their value-sets shall contain the original values. + /// A copy shall keep its original owner + /// + CopyKeepValues + } +} diff --git a/CDP4Dal/Operations/PostOperation.cs b/CDP4DalCommon/Protocol/Operations/PostOperation.cs similarity index 80% rename from CDP4Dal/Operations/PostOperation.cs rename to CDP4DalCommon/Protocol/Operations/PostOperation.cs index 95d3eb250..36c9bd4d6 100644 --- a/CDP4Dal/Operations/PostOperation.cs +++ b/CDP4DalCommon/Protocol/Operations/PostOperation.cs @@ -1,78 +1,79 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2020 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public License -// along with this program; if not, write to the Free Software Foundation, -// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -// -------------------------------------------------------------------------------------------------------------------- - -namespace CDP4Dal.Operations -{ - using System.Collections.Generic; - using CDP4Common; - using CDP4Common.Dto; - using CDP4Common.DTO; - - /// - /// The abstract super class from which all POST operations derive. - /// - public abstract class PostOperation - { - /// - /// Initializes a new instance of the class - /// - protected PostOperation() - { - this.Delete = new List(); - this.Create = new List(); - this.Update = new List(); - this.Copy = new List(); - } - - /// - /// Gets or sets the collection of DTOs to delete. - /// - public abstract List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public abstract List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public abstract List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to copy. - /// - public abstract List Copy { get; set; } - - /// - /// Populate the current with the content based on the - /// provided - /// - /// - /// The that contains all the s that need to be - /// updated to the data-source - /// - public abstract void ConstructFromOperation(Operation operation); - } -} +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalCommon.Protocol.Operations +{ + using System.Collections.Generic; + + using CDP4Common; + using CDP4Common.Dto; + using CDP4Common.DTO; + + /// + /// The abstract super class from which all POST operations derive. + /// + public abstract class PostOperation + { + /// + /// Initializes a new instance of the class + /// + protected PostOperation() + { + this.Delete = new List(); + this.Create = new List(); + this.Update = new List(); + this.Copy = new List(); + } + + /// + /// Gets or sets the collection of DTOs to delete. + /// + public abstract List Delete { get; set; } + + /// + /// Gets or sets the collection of DTOs to create. + /// + public abstract List Create { get; set; } + + /// + /// Gets or sets the collection of DTOs to update. + /// + public abstract List Update { get; set; } + + /// + /// Gets or sets the collection of DTOs to copy. + /// + public abstract List Copy { get; set; } + + /// + /// Populate the current with the content based on the + /// provided + /// + /// + /// The that contains all the s that need to be + /// updated to the data-source + /// + public abstract void ConstructFromOperation(Operation operation); + } +} diff --git a/CDP4DalCommon/Tasks/CometTask.cs b/CDP4DalCommon/Protocol/Tasks/CometTask.cs similarity index 92% rename from CDP4DalCommon/Tasks/CometTask.cs rename to CDP4DalCommon/Protocol/Tasks/CometTask.cs index 057d4357a..1a617d2fa 100644 --- a/CDP4DalCommon/Tasks/CometTask.cs +++ b/CDP4DalCommon/Protocol/Tasks/CometTask.cs @@ -2,7 +2,7 @@ // // Copyright (c) 2015-2024 RHEA System S.A. // -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -22,7 +22,7 @@ // // ------------------------------------------------------------------------------------------------------------------------------- -namespace CDP4DalCommon.Tasks +namespace CDP4DalCommon.Protocol.Tasks { using System; @@ -71,7 +71,7 @@ public CometTask() /// /// A value of -1 is returned when the task is still running or not completed with success /// - public readonly int Duration => this.ComputeDuration(); + public readonly int Duration => ComputeDuration(); /// /// Gets or sets the at which the was started @@ -107,12 +107,12 @@ public CometTask() /// The computated duration private readonly int ComputeDuration() { - if (!this.FinishedAt.HasValue || !this.StartedAt.HasValue) + if (!FinishedAt.HasValue || !StartedAt.HasValue) { return -1; } - var timeSpan = this.FinishedAt.Value - this.StartedAt.Value; + var timeSpan = FinishedAt.Value - StartedAt.Value; return (int)timeSpan.TotalSeconds; } } diff --git a/CDP4DalCommon/Tasks/StatusKind.cs b/CDP4DalCommon/Protocol/Tasks/StatusKind.cs similarity index 57% rename from CDP4DalCommon/Tasks/StatusKind.cs rename to CDP4DalCommon/Protocol/Tasks/StatusKind.cs index 9f903b951..31bb5596c 100644 --- a/CDP4DalCommon/Tasks/StatusKind.cs +++ b/CDP4DalCommon/Protocol/Tasks/StatusKind.cs @@ -1,29 +1,28 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. // -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // -// This file is part of CDP4-COMET Webservices Community Edition. -// The CDP4-COMET Web Services Community Edition is the RHEA implementation of ECSS-E-TM-10-25 Annex A and Annex C. -// This is an auto-generated class. Any manual changes to this file will be overwritten! +// This file is part of CDP4-COMET SDK Community Edition // -// The CDP4-COMET Web Services Community Edition is free software; you can redistribute it and/or -// modify it under the terms of the GNU Affero General Public +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. // -// The CDP4-COMET Web Services Community Edition is distributed in the hope that it will be useful, +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // -// You should have received a copy of the GNU Affero General Public License -// along with this program. If not, see . +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- -namespace CDP4DalCommon.Tasks +namespace CDP4DalCommon.Protocol.Tasks { using System.Threading.Tasks; @@ -52,4 +51,4 @@ public enum StatusKind /// CANCELLED } -} \ No newline at end of file +} diff --git a/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj b/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj new file mode 100644 index 000000000..765eb528d --- /dev/null +++ b/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj @@ -0,0 +1,44 @@ + + + + net47;net471;net472;net48;netstandard2.0;netstandard2.1 + RHEA System S.A. + latest + CDP4DalJsonSerializer Community Edition + 26.6.0 + JsonSerializer for the CDP4DalCommon types + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Nathanael, Antoine, Omar, Jaime + CDP4DalJsonSerializer-CE + true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + true + latest + + + + \ + true + + + \ + true + + + + + + + diff --git a/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs new file mode 100644 index 000000000..5b9e6f660 --- /dev/null +++ b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs @@ -0,0 +1,86 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalJsonSerializer +{ + using System; + + using CDP4Common.MetaInfo; + + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer.JsonConverter; + + using CDP4JsonSerializer; + + /// + /// The is a that also supports (de)serialization of + /// + /// + public class Cdp4DalJsonSerializer : Cdp4JsonSerializer + { + /// + /// Asserts that the have to be ignored + /// + private readonly bool ignorePostOperationCopyProperty; + + /// + /// Initializes a new instance of the class. + /// + /// + /// The meta Info Provider. + /// + /// + /// The supported version of the data-model + /// + /// Asserts that the have to be ignored + public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedVersion, bool ignorePostOperationCopyProperty = false) + { + this.ignorePostOperationCopyProperty = ignorePostOperationCopyProperty; + + this.Initialize(metaInfoProvider, supportedVersion); + } + + /// + /// Initializes a new instance of the class. + /// + /// Asserts that the have to be ignored + public Cdp4DalJsonSerializer(bool ignorePostOperationCopyProperty = false) + { + this.ignorePostOperationCopyProperty = ignorePostOperationCopyProperty; + } + + /// + /// Initialize this instance with the required and supported + /// + /// The + /// The supported + public override void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) + { + base.Initialize(metaInfoProvider, supportedVersion); + + this.JsonSerializerOptions.Converters.Add(new PostOperationJsonConverter(this.ignorePostOperationCopyProperty)); + } + } +} diff --git a/CDP4DalJsonSerializer/Extensions/JsonElementExtensions.cs b/CDP4DalJsonSerializer/Extensions/JsonElementExtensions.cs new file mode 100644 index 000000000..1a7d927ff --- /dev/null +++ b/CDP4DalJsonSerializer/Extensions/JsonElementExtensions.cs @@ -0,0 +1,70 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalJsonSerializer.Extensions +{ + using System.Collections.Generic; + using System.Text.Json; + + using CDP4Common; + using CDP4Common.Dto; + using CDP4Common.DTO; + + using CDP4DalCommon.Protocol.Operations; + + /// + /// Extension class for + /// + public static class JsonElementExtensions + { + /// + /// Deserialize the content of the to the + /// + /// The + /// The that will receive new value properties + /// The + public static void DeserializePostOperation(this JsonElement element, PostOperation postOperation, JsonSerializerOptions serializerOptions) + { + if (element.TryGetProperty("_delete", out var deleteElement)) + { + postOperation.Delete = deleteElement.Deserialize>(serializerOptions); + } + + if (element.TryGetProperty("_create", out var createElement)) + { + postOperation.Create = createElement.Deserialize>(serializerOptions); + } + + if (element.TryGetProperty("_update", out var updateElement)) + { + postOperation.Update = updateElement.Deserialize>(serializerOptions); + } + + if (element.TryGetProperty("_copy", out var copyElement)) + { + postOperation.Copy = copyElement.Deserialize>(serializerOptions); + } + } + } +} diff --git a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs new file mode 100644 index 000000000..90b70787c --- /dev/null +++ b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs @@ -0,0 +1,150 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4DalJsonSerializer.JsonConverter +{ + using System; + using System.IO; + using System.Text.Json; + using System.Text.Json.Serialization; + + using CDP4Common.Polyfills; + + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer.Extensions; + + using NLog; + + /// + /// The for s + /// + public class PostOperationJsonConverter: JsonConverter + { + /// + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Asserts that the have to be ignored + /// + private readonly bool ignoreCopyProperty; + + /// + /// Initializes a new instance. + /// + /// Asserts that the have to be ignored + public PostOperationJsonConverter(bool ignoreCopyProperty = false) + { + this.ignoreCopyProperty = ignoreCopyProperty; + } + + /// + /// Override of the can convert type check. + /// + /// + /// The object type. + /// + /// + /// true if this converter is to be used. + /// + public override bool CanConvert(Type typeToConvert) + { + return typeof(PostOperation).QueryIsAssignableFrom(typeToConvert); + } + + /// Reads and converts the JSON to type . + /// The reader. + /// The type to convert. + /// An object that specifies serialization options to use. + /// The converted value. + public override PostOperation Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) + { + if (!JsonElement.TryParseValue(ref reader, out var jsonElement)) + { + Logger.Error("The data object in the JSON array could not be cast to a JsonElement type."); + throw new InvalidDataException("The data object in the JSON array could not be cast to a JObject type."); + } + + var initializedPostOperation = Activator.CreateInstance(typeToConvert); + + if (initializedPostOperation is not PostOperation postOperation) + { + Logger.Error($"The request Type {typeToConvert.Name} is not a PostOperation"); + throw new InvalidDataException($"The request Type {typeToConvert.Name} is not a PostOperation"); + } + + jsonElement?.DeserializePostOperation(postOperation, options); + return postOperation; + } + + /// Writes a specified value as JSON. + /// The writer to write to. + /// The value to convert to JSON. + /// An object that specifies serialization options to use. + public override void Write(Utf8JsonWriter writer, PostOperation value, JsonSerializerOptions options) + { + writer.WriteStartObject(); + writer.WriteStartArray("_delete"); + + foreach (var toDelete in value.Delete) + { + JsonSerializer.Serialize(writer, toDelete, options); + } + + writer.WriteEndArray(); + writer.WriteStartArray("_create"); + + foreach (var toCreate in value.Create) + { + JsonSerializer.Serialize(writer, toCreate, options); + } + + writer.WriteEndArray(); + writer.WriteStartArray("_update"); + + foreach (var toUpdate in value.Update) + { + JsonSerializer.Serialize(writer, toUpdate, options); + } + + writer.WriteEndArray(); + + if (!this.ignoreCopyProperty) + { + writer.WriteStartArray("_copy"); + + foreach (var toCopy in value.Copy) + { + JsonSerializer.Serialize(writer, toCopy, options); + } + + writer.WriteEndArray(); + } + + writer.WriteEndObject(); + } + } +} diff --git a/CDP4JsonFileDal.NetCore.Tests/JsonFileDalTestFixture.cs b/CDP4JsonFileDal.NetCore.Tests/JsonFileDalTestFixture.cs index 00a37578a..38f469a04 100644 --- a/CDP4JsonFileDal.NetCore.Tests/JsonFileDalTestFixture.cs +++ b/CDP4JsonFileDal.NetCore.Tests/JsonFileDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonFileDal.NetCore.Tests { @@ -32,6 +32,7 @@ namespace CDP4JsonFileDal.NetCore.Tests using System.Threading; using System.Threading.Tasks; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.DTO; using CDP4Common.Types; @@ -41,7 +42,7 @@ namespace CDP4JsonFileDal.NetCore.Tests using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4JsonFileDal; + using CDP4DalCommon.Protocol.Operations; using Moq; @@ -69,9 +70,6 @@ namespace CDP4JsonFileDal.NetCore.Tests using SampledFunctionParameterType = CDP4Common.SiteDirectoryData.SampledFunctionParameterType; using ElementDefinition = CDP4Common.EngineeringModelData.ElementDefinition; using Parameter = CDP4Common.EngineeringModelData.Parameter; - - using CDP4Common; - using OrganizationalParticipant = CDP4Common.SiteDirectoryData.OrganizationalParticipant; [TestFixture] @@ -530,7 +528,7 @@ public async Task VerifyWriteOfIncompatibleVersionFile() var domain = siteDirectory.Domain.First(); var model = new CDP4Common.EngineeringModelData.EngineeringModel(modelSetup.EngineeringModelIid, newSession.Assembler.Cache, newDal.Credentials.Uri) - { EngineeringModelSetup = modelSetup }; + { EngineeringModelSetup = modelSetup }; var iteration = new CDP4Common.EngineeringModelData.Iteration(this.iterationIid, newSession.Assembler.Cache, newDal.Credentials.Uri); @@ -590,7 +588,7 @@ public async Task VerifyWriteOfCompatibleVersionFile() var domain = siteDirectory.Domain.First(); var model = new CDP4Common.EngineeringModelData.EngineeringModel(modelSetup.EngineeringModelIid, newSession.Assembler.Cache, newDal.Credentials.Uri) - { EngineeringModelSetup = modelSetup }; + { EngineeringModelSetup = modelSetup }; var iteration = new CDP4Common.EngineeringModelData.Iteration(this.iterationIid, newSession.Assembler.Cache, newDal.Credentials.Uri); @@ -690,6 +688,7 @@ private void CreateBasicModel() iterationSetup.IterationIid = this.iterationIid; iterationSetupPoco.IterationIid = this.iterationIid; + // EngineeringModel this.model = new EngineeringModel(Guid.NewGuid(), this.cache, this.credentials.Uri); this.modelSetupId = Guid.NewGuid(); diff --git a/CDP4JsonFileDal.Tests/JsonFileDalTestFixture.cs b/CDP4JsonFileDal.Tests/JsonFileDalTestFixture.cs index 406517edb..127a0018a 100644 --- a/CDP4JsonFileDal.Tests/JsonFileDalTestFixture.cs +++ b/CDP4JsonFileDal.Tests/JsonFileDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonFileDal.Tests { @@ -32,6 +32,7 @@ namespace CDP4JsonFileDal.Tests using System.Threading; using System.Threading.Tasks; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.DTO; using CDP4Common.Types; @@ -41,7 +42,7 @@ namespace CDP4JsonFileDal.Tests using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4JsonFileDal; + using CDP4DalCommon.Protocol.Operations; using Moq; @@ -69,9 +70,6 @@ namespace CDP4JsonFileDal.Tests using SampledFunctionParameterType = CDP4Common.SiteDirectoryData.SampledFunctionParameterType; using ElementDefinition = CDP4Common.EngineeringModelData.ElementDefinition; using Parameter = CDP4Common.EngineeringModelData.Parameter; - - using CDP4Common; - using OrganizationalParticipant = CDP4Common.SiteDirectoryData.OrganizationalParticipant; [TestFixture] @@ -252,7 +250,7 @@ public async Task VerifyThatReadReturnsCorrectDTO() // General assertions for any kind of Thing we read Assert.That(readResult, Is.Not.Null); Assert.That(readResult.Count, Is.Not.EqualTo(1)); - + var iter1 = readResult.Single(d => d.ClassKind == ClassKind.Iteration); Assert.That(iter1.ClassKind, Is.EqualTo(iterObject.ClassKind)); Assert.That(iter1.Iid, Is.EqualTo(iterObject.Iid)); @@ -436,7 +434,7 @@ public void VerifyCtorWithVersionAndCopyright() Assert.That(this.dal.Serializer.RequestDataModelVersion.Major, Is.EqualTo(1)); Assert.That(this.dal.Serializer.RequestDataModelVersion.Minor, Is.EqualTo(0)); Assert.That(this.dal.Serializer.RequestDataModelVersion.Build, Is.EqualTo(0)); - + this.dal.UpdateExchangeFileHeader(new Person { ShortName = "admin" }); Assert.That(this.dal.FileHeader, Is.InstanceOf()); @@ -689,6 +687,7 @@ private void CreateBasicModel() iterationSetup.IterationIid = this.iterationIid; iterationSetupPoco.IterationIid = this.iterationIid; + // EngineeringModel this.model = new EngineeringModel(Guid.NewGuid(), this.cache, this.credentials.Uri); this.modelSetupId = Guid.NewGuid(); @@ -732,10 +731,10 @@ private void AddExtraThingsForExportFilteringTests() var elementDefinition2 = new ElementDefinition(Guid.NewGuid(), this.cache, this.credentials.Uri); elementDefinition2.ShortName = "ED2"; elementDefinition2.Owner = this.model.EngineeringModelSetup.ActiveDomain.First(); - + var elementDefinition3 = new ElementDefinition(Guid.NewGuid(), this.cache, this.credentials.Uri); elementDefinition3.ShortName = "ED3"; - + var elementDefinition4 = new ElementDefinition(Guid.NewGuid(), this.cache, this.credentials.Uri); elementDefinition4.ShortName = "ED4"; elementDefinition4.Owner = new DomainOfExpertise(Guid.NewGuid(), this.cache, this.credentials.Uri); //Not in file @@ -754,7 +753,7 @@ private void AddExtraThingsForExportFilteringTests() elementDefinition1.Parameter.Add(sampledFunctionParameter1); elementDefinition2.Parameter.Add(sampledFunctionParameter2); - + this.iterationPoco.Element.Add(elementDefinition1); this.iterationPoco.Element.Add(elementDefinition2); this.iterationPoco.Element.Add(elementDefinition3); @@ -770,7 +769,7 @@ private void AddExtraThingsForExportFilteringTests() parameterOverride.ValueSet.Add(new CDP4Common.EngineeringModelData.ParameterOverrideValueSet(Guid.NewGuid(), this.cache, this.credentials.Uri)); parameterOverride.ValueSet.First().ParameterValueSet = sampledFunctionParameter2.ValueSet.First(); elementUsage.ParameterOverride.Add(parameterOverride); - + elementDefinition1.ContainedElement.Add(elementUsage); var citation = new CDP4Common.CommonData.Citation(Guid.NewGuid(), this.cache, this.credentials.Uri); diff --git a/CDP4JsonFileDal/CDP4JsonFileDal.csproj b/CDP4JsonFileDal/CDP4JsonFileDal.csproj index 45b8cec59..5023fcb9b 100644 --- a/CDP4JsonFileDal/CDP4JsonFileDal.csproj +++ b/CDP4JsonFileDal/CDP4JsonFileDal.csproj @@ -37,6 +37,7 @@ + diff --git a/CDP4JsonFileDal/JsonFileDal.cs b/CDP4JsonFileDal/JsonFileDal.cs index cde6bd66e..160486179 100644 --- a/CDP4JsonFileDal/JsonFileDal.cs +++ b/CDP4JsonFileDal/JsonFileDal.cs @@ -1,21 +1,21 @@ // ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2023 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexandervan Delft, Nathanael Smiechowski, Ahmed Abulwafa Ahmed -// -// This file is part of COMET-SDK Community Edition -// -// The CDP4-COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -26,7 +26,6 @@ namespace CDP4JsonFileDal { using System; using System.Collections.Generic; - using System.ComponentModel; using System.Diagnostics; using System.IO; using System.Linq; @@ -46,11 +45,12 @@ namespace CDP4JsonFileDal using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; - using CDP4JsonFileDal.Json; + using CDP4DalJsonSerializer; - using CDP4JsonSerializer; + using CDP4JsonFileDal.Json; using Ionic.Zip; @@ -61,7 +61,6 @@ namespace CDP4JsonFileDal using Thing = CDP4Common.DTO.Thing; #if NETFRAMEWORK using System.ComponentModel.Composition; - using Newtonsoft.Json.Linq; #endif /// @@ -119,7 +118,7 @@ public class JsonFileDal : Dal /// public JsonFileDal() { - this.Serializer = new Cdp4JsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); } /// @@ -138,7 +137,7 @@ public JsonFileDal(Version dalVersion) this.DalVersion = dalVersion; } - this.Serializer = new Cdp4JsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); } /// @@ -157,9 +156,9 @@ public void UpdateExchangeFileHeader(Person person, string headerCopyright = nul } /// - /// Gets the + /// Gets the /// - public Cdp4JsonSerializer Serializer { get; private set; } + public Cdp4DalJsonSerializer Serializer { get; private set; } /// /// Gets the value indicating whether this is read only @@ -428,7 +427,7 @@ private IEnumerable RemoveUnlinkedMandatoryReferences(IEnumerable if (newThingsToRemove.Any()) { dtosToCheck = dtosToCheck.Where(x => !newThingsToRemove.Contains(x.Iid)).ToList(); - iidsToCheck.RemoveWhere(x=> newThingsToRemove.Contains(x)); + iidsToCheck.RemoveWhere(x => newThingsToRemove.Contains(x)); } else { diff --git a/CDP4JsonSerializer.NetCore.Tests/Helper/SerializerHelperTestFixture.cs b/CDP4JsonSerializer.NetCore.Tests/Helper/SerializerHelperTestFixture.cs index c9bc3fa87..c0e6b4916 100644 --- a/CDP4JsonSerializer.NetCore.Tests/Helper/SerializerHelperTestFixture.cs +++ b/CDP4JsonSerializer.NetCore.Tests/Helper/SerializerHelperTestFixture.cs @@ -1,32 +1,35 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// // This file is part of CDP4-COMET SDK Community Edition -// +// // The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// +// // The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.Tests.Helper { using System; using System.Collections.Generic; + using System.IO; using System.Linq; + using System.Text.Json; + using System.Text.Json.Nodes; using CDP4Common.EngineeringModelData; using CDP4Common.MetaInfo; @@ -54,17 +57,23 @@ public void VerifyThatToJsonObjectOfOrderedItemReturnsJObject() object value = null; value = System.Convert.ChangeType(123, Nullable.GetUnderlyingType(propertyInfo.PropertyType)); propertyInfo.SetValue(orderedItem, value); + var stream = new MemoryStream(); + var utf8Writer = new Utf8JsonWriter(stream); + utf8Writer.WriteOrderedItem(orderedItem); + utf8Writer.Flush(); + stream.Position = 0; + var ut8Reader = new Utf8JsonReader(stream.ToArray()); - var jObject = SerializerHelper.ToJsonObject(orderedItem); - Assert.That(jObject.Properties().Count(), Is.EqualTo(3)); + var jObject = JsonObject.Create(JsonElement.ParseValue(ref ut8Reader)); + Assert.That(jObject.AsEnumerable().Count(), Is.EqualTo(3)); - var k = jObject.Property("k"); + jObject.TryGetPropertyValue("k", out var k); Assert.That(k, Is.Not.Null); - var v = jObject.Property("v"); + jObject.TryGetPropertyValue("v", out var v); Assert.That(v, Is.Not.Null); - var m = jObject.Property("m"); + jObject.TryGetPropertyValue("m", out var m); Assert.That(m, Is.Not.Null); } @@ -75,10 +84,11 @@ public void Verify_that_ParameterValueSet_is_serialized_and_deserialized() values.Add("this is a\nnewline"); values.Add("this is another\nnewline"); - var engineeringModel = new EngineeringModel {Iid = Guid.Parse("5643764e-f880-44bf-90ae-361f6661ceae")}; - var iteration = new Iteration {Iid = Guid.Parse("f744ae63-cf36-4cc4-8d76-e83edd44f6d2")}; - var elementDefinition = new ElementDefinition {Iid = Guid.Parse("f7f173ea-a742-42a5-81f1-59da2f470f16") }; - var parameter = new Parameter {Iid = Guid.Parse("607764de-7598-4be2-9a95-34669de273e3") }; + var engineeringModel = new EngineeringModel { Iid = Guid.Parse("5643764e-f880-44bf-90ae-361f6661ceae") }; + var iteration = new Iteration { Iid = Guid.Parse("f744ae63-cf36-4cc4-8d76-e83edd44f6d2") }; + var elementDefinition = new ElementDefinition { Iid = Guid.Parse("f7f173ea-a742-42a5-81f1-59da2f470f16") }; + var parameter = new Parameter { Iid = Guid.Parse("607764de-7598-4be2-9a95-34669de273e3") }; + var parameterValueSet = new ParameterValueSet { Iid = Guid.Parse("2366c662-b857-4313-85ea-51f9bf4588b1"), Manual = new ValueArray(values) @@ -171,7 +181,7 @@ the CEND sequence.If I need to use CEND I must escape one of the "; - private static readonly string[] TestStrings = + private static readonly string[] TestStrings = { "value with trailing spaces ", "value with trailing space ", diff --git a/CDP4JsonSerializer.NetCore.Tests/JsonSerializerTestFixture.cs b/CDP4JsonSerializer.NetCore.Tests/JsonSerializerTestFixture.cs index b3ca5daf5..9d64fe941 100644 --- a/CDP4JsonSerializer.NetCore.Tests/JsonSerializerTestFixture.cs +++ b/CDP4JsonSerializer.NetCore.Tests/JsonSerializerTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// // This file is part of CDP4-COMET SDK Community Edition -// +// // The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// +// // The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.Tests { @@ -41,8 +41,6 @@ namespace CDP4JsonSerializer.Tests using CDP4JsonSerializer.Tests.Helper; - using Newtonsoft.Json; - using NUnit.Framework; using Dto = CDP4Common.DTO; @@ -117,7 +115,7 @@ public void VerifyThatSerializeTimeCorrectly() using var reader = new StreamReader(memoryStream); var txt = reader.ReadToEnd(); - + Assert.That(txt, Does.Not.Contain("2222-02-02T22:22:22.222222")); Assert.That(txt, Does.Contain("2222-02-02T22:22:22.222Z")); } @@ -407,7 +405,7 @@ public void VerifyThatSerializationofOperationsWorks() result.Update.Single(x => x["Iid"].ToString() == subscriptionValueset.Iid.ToString()); var valueArray = (ValueArray)subscriptionValueSetClasslessDto["Manual"]; - + Assert.That(subscriptionValueSetClasslessDto["Iid"] is Guid, Is.True); Assert.That(subscriptionValueSetClasslessDto["ClassKind"] is ClassKind, Is.True); @@ -457,7 +455,7 @@ public void VerifyThatSerializeGiveSameInput() using var reader = new StreamReader(stream); var serializerResult = reader.ReadToEnd().Replace("\r", string.Empty).Replace("\n", string.Empty).Replace("\t", string.Empty).Replace(" ", string.Empty).Trim(); - + Assert.That(response.Length, Is.EqualTo(serializerResult.Length)); } } @@ -498,7 +496,7 @@ public void VerifyThatValueSetDeserializationIsCorrectForStringThatRepresentEsca using var reader = new StreamReader(stream); var serializerResult = reader.ReadToEnd().Replace("\r", string.Empty).Replace("\n", string.Empty).Replace("\t", string.Empty).Replace(" ", string.Empty).Trim(); - + Assert.That(serializedParameterValueSet.Length, Is.EqualTo(serializerResult.Length)); } } @@ -611,19 +609,16 @@ private class TestPostOperation /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] public List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public List Update { get; set; } /// diff --git a/CDP4JsonSerializer.Tests/Helper/SerializerHelperTestFixture.cs b/CDP4JsonSerializer.Tests/Helper/SerializerHelperTestFixture.cs index d7b6da8ce..3ea93b211 100644 --- a/CDP4JsonSerializer.Tests/Helper/SerializerHelperTestFixture.cs +++ b/CDP4JsonSerializer.Tests/Helper/SerializerHelperTestFixture.cs @@ -1,33 +1,36 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// // This file is part of CDP4-COMET SDK Community Edition -// +// // The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// +// // The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.Tests.Helper { using System; using System.Collections.Generic; + using System.IO; using System.Linq; - + using System.Text.Json; + using System.Text.Json.Nodes; + using CDP4Common.EngineeringModelData; using CDP4Common.MetaInfo; using CDP4Common.Types; @@ -45,23 +48,30 @@ public void VerifyThatToJsonObjectOfOrderedItemReturnsJObject() { var uniqueIdentifier = Guid.NewGuid(); - var orderedItem = new OrderedItem {K = 1, V = uniqueIdentifier}; + var orderedItem = new OrderedItem { K = 1, V = uniqueIdentifier }; var propertyInfo = orderedItem.GetType().GetProperty("M"); - var value = System.Convert.ChangeType(123, Nullable.GetUnderlyingType(propertyInfo.PropertyType)); + object value = null; + value = System.Convert.ChangeType(123, Nullable.GetUnderlyingType(propertyInfo.PropertyType)); propertyInfo.SetValue(orderedItem, value); + var stream = new MemoryStream(); + var utf8Writer = new Utf8JsonWriter(stream); + utf8Writer.WriteOrderedItem(orderedItem); + utf8Writer.Flush(); + stream.Position = 0; + var ut8Reader = new Utf8JsonReader(stream.ToArray()); - var jObject = orderedItem.ToJsonObject(); - Assert.That(jObject.Properties().Count(), Is.EqualTo(3)); + var jObject = JsonObject.Create(JsonElement.ParseValue(ref ut8Reader)); + Assert.That(jObject.AsEnumerable().Count(), Is.EqualTo(3)); - var k = jObject.Property("k"); + jObject.TryGetPropertyValue("k", out var k); Assert.That(k, Is.Not.Null); - var v = jObject.Property("v"); + jObject.TryGetPropertyValue("v", out var v); Assert.That(v, Is.Not.Null); - var m = jObject.Property("m"); + jObject.TryGetPropertyValue("m", out var m); Assert.That(m, Is.Not.Null); } @@ -113,7 +123,7 @@ public void Verify_that_a_ValueArray_is_serialized_and_deserialized([ValueSource Assert.That(resultjson, Is.EqualTo(json), $"Json creation failed for string \"{input}\"."); } - + private const string JsonString = @"{""widget"": { ""debug"": ""on"", ""window"": { @@ -170,7 +180,7 @@ the CEND sequence.If I need to use CEND I must escape one of the "; - private static readonly string[] TestStrings = + private static readonly string[] TestStrings = { "value with trailing spaces ", "value with trailing space ", @@ -212,4 +222,4 @@ the CEND sequence.If I need to use CEND I must escape one of the JsonString }; } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer.Tests/JsonSerializerTestFixture.cs b/CDP4JsonSerializer.Tests/JsonSerializerTestFixture.cs index 9ce52fa9f..6095cbbe1 100644 --- a/CDP4JsonSerializer.Tests/JsonSerializerTestFixture.cs +++ b/CDP4JsonSerializer.Tests/JsonSerializerTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// // This file is part of CDP4-COMET SDK Community Edition -// +// // The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// +// // The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.Tests { @@ -30,6 +30,7 @@ namespace CDP4JsonSerializer.Tests using System.Diagnostics; using System.IO; using System.Linq; + using System.Text.Json.Serialization; using CDP4Common; using CDP4Common.CommonData; @@ -41,8 +42,6 @@ namespace CDP4JsonSerializer.Tests using CDP4JsonSerializer.Tests.Helper; - using Newtonsoft.Json; - using NUnit.Framework; using Dto = CDP4Common.DTO; @@ -170,7 +169,7 @@ public void VerifyThatValueArrayAreSerializedCorrectly() var txt = reader.ReadToEnd(); // output: "manual":"[\"123\",\"abc\"]" - Assert.That(txt, Does.Contain("\"manual\":\"[\\\"123\\\",\\\"abc\\\"]\"")); + Assert.That(txt, Does.Contain("\"manual\":\"[\\\"123\\\",\\\"abc\\\"]\"")); } } } @@ -412,9 +411,10 @@ public void VerifyThatSerializationofOperationsWorks() // necessary memoryStream.Position = 0; - + var content = new StreamReader(memoryStream).ReadToEnd(); + memoryStream.Position = 0; var result = this.serializer.Deserialize(memoryStream); - + Assert.That(result.Delete.Count, Is.EqualTo(1)); Assert.That(result.Create.Count, Is.EqualTo(1)); Assert.That(result.Update.Count, Is.EqualTo(2)); @@ -617,19 +617,19 @@ private class TestPostOperation /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] + [JsonPropertyName("_delete")] public List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] + [JsonPropertyName("_create")] public List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] + [JsonPropertyName("_update")] public List Update { get; set; } /// diff --git a/CDP4JsonSerializer.Tests/PostOperation/CdpPostOperation.cs b/CDP4JsonSerializer.Tests/PostOperation/CdpPostOperation.cs index 12dbafe1f..ed7bacaa7 100644 --- a/CDP4JsonSerializer.Tests/PostOperation/CdpPostOperation.cs +++ b/CDP4JsonSerializer.Tests/PostOperation/CdpPostOperation.cs @@ -1,51 +1,50 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// // This file is part of CDP4-COMET SDK Community Edition -// +// // The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// +// // The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.Tests.Cdp4PostOperation { using System.Collections.Generic; + using System.Text.Json.Serialization; using CDP4Common; using CDP4Common.DTO; - using Newtonsoft.Json; - /// /// A CdpPostOperation class used for testing purposes /// public class CdpPostOperation { - [JsonProperty("_delete")] + [JsonPropertyName("_delete")] public List Delete { get; set; } - [JsonProperty("_create")] + [JsonPropertyName("_create")] public List Create { get; set; } - [JsonProperty("_update")] + [JsonPropertyName("_update")] public List Update { get; set; } - [JsonProperty("_copy")] + [JsonPropertyName("_copy")] public List Copy { get; set; } } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs index 12f4beb26..7e7c2b211 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,151 +28,287 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ActionItemResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ActionItem FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var actionItem = new CDP4Common.DTO.ActionItem(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ActionItemResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actionee"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - actionItem.Actionee = jObject["actionee"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actor"].IsNullOrEmpty()) + var actionItem = new CDP4Common.DTO.ActionItem(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("actionee"u8, out var actioneeProperty)) { - actionItem.Actor = jObject["actor"].ToObject(); + if(actioneeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale actionee property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Actionee = actioneeProperty.GetGuid(); + } } - if (!jObject["approvedBy"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - actionItem.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + actionItem.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - actionItem.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - actionItem.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + actionItem.Category.Add(element.GetGuid()); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - actionItem.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["closeOutDate"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("closeOutDate"u8, out var closeOutDateProperty)) { - actionItem.CloseOutDate = jObject["closeOutDate"].ToObject(); + if(closeOutDateProperty.ValueKind == JsonValueKind.Null) + { + actionItem.CloseOutDate = null; + } + else + { + actionItem.CloseOutDate = closeOutDateProperty.GetDateTime(); + } } - if (!jObject["closeOutStatement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("closeOutStatement"u8, out var closeOutStatementProperty)) { - actionItem.CloseOutStatement = jObject["closeOutStatement"].ToObject(); + if(closeOutStatementProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale closeOutStatement property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.CloseOutStatement = closeOutStatementProperty.GetString(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - actionItem.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - actionItem.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - actionItem.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + actionItem.Discussion.Add(element.GetGuid()); + } } - if (!jObject["dueDate"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("dueDate"u8, out var dueDateProperty)) { - actionItem.DueDate = jObject["dueDate"].ToObject(); + if(dueDateProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale dueDate property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.DueDate = dueDateProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - actionItem.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + actionItem.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - actionItem.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + actionItem.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - actionItem.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - actionItem.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - actionItem.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - actionItem.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + actionItem.PrimaryAnnotatedThing = null; + } + else + { + actionItem.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - actionItem.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + actionItem.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - actionItem.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - actionItem.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + actionItem.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - actionItem.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - actionItem.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - actionItem.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the actionItem {id} is null", actionItem.Iid); + } + else + { + actionItem.Title = titleProperty.GetString(); + } } return actionItem; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs index ca3dbc24e..9ff4be99c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,112 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ActualFiniteStateListResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ActualFiniteStateList FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ActualFiniteStateList FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var actualFiniteStateList = new CDP4Common.DTO.ActualFiniteStateList(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ActualFiniteStateListResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - actualFiniteStateList.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actualState"].IsNullOrEmpty()) + var actualFiniteStateList = new CDP4Common.DTO.ActualFiniteStateList(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("actualState"u8, out var actualStateProperty) && actualStateProperty.ValueKind != JsonValueKind.Null) { - actualFiniteStateList.ActualState.AddRange(jObject["actualState"].ToObject>()); + foreach(var element in actualStateProperty.EnumerateArray()) + { + actualFiniteStateList.ActualState.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - actualFiniteStateList.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + actualFiniteStateList.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - actualFiniteStateList.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + actualFiniteStateList.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["excludeOption"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludeOption"u8, out var excludeOptionProperty) && excludeOptionProperty.ValueKind != JsonValueKind.Null) { - actualFiniteStateList.ExcludeOption.AddRange(jObject["excludeOption"].ToObject>()); + foreach(var element in excludeOptionProperty.EnumerateArray()) + { + actualFiniteStateList.ExcludeOption.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - actualFiniteStateList.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + } + else + { + actualFiniteStateList.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - actualFiniteStateList.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + } + else + { + actualFiniteStateList.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["possibleFiniteStateList"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleFiniteStateList"u8, out var possibleFiniteStateListProperty)) { - actualFiniteStateList.PossibleFiniteStateList.AddRange(jObject["possibleFiniteStateList"].ToOrderedItemCollection()); + actualFiniteStateList.PossibleFiniteStateList.AddRange(possibleFiniteStateListProperty.ToOrderedItemCollection()); } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - actualFiniteStateList.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + } + else + { + actualFiniteStateList.ThingPreference = thingPreferenceProperty.GetString(); + } } return actualFiniteStateList; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs index 11f02c17f..152686837 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,99 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ActualFiniteStateResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ActualFiniteState FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ActualFiniteState FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var actualFiniteState = new CDP4Common.DTO.ActualFiniteState(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ActualFiniteStateResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - actualFiniteState.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var actualFiniteState = new CDP4Common.DTO.ActualFiniteState(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - actualFiniteState.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + actualFiniteState.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - actualFiniteState.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + actualFiniteState.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["kind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("kind"u8, out var kindProperty)) { - actualFiniteState.Kind = jObject["kind"].ToObject(); + if(kindProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale kind property of the actualFiniteState {id} is null", actualFiniteState.Iid); + } + else + { + actualFiniteState.Kind = ActualFiniteStateKindDeserializer.Deserialize(kindProperty); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - actualFiniteState.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the actualFiniteState {id} is null", actualFiniteState.Iid); + } + else + { + actualFiniteState.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["possibleState"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleState"u8, out var possibleStateProperty) && possibleStateProperty.ValueKind != JsonValueKind.Null) { - actualFiniteState.PossibleState.AddRange(jObject["possibleState"].ToObject>()); + foreach(var element in possibleStateProperty.EnumerateArray()) + { + actualFiniteState.PossibleState.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - actualFiniteState.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the actualFiniteState {id} is null", actualFiniteState.Iid); + } + else + { + actualFiniteState.ThingPreference = thingPreferenceProperty.GetString(); + } } return actualFiniteState; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs index 601c35831..56a4aacfd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class AliasResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Alias FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var alias = new CDP4Common.DTO.Alias(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the AliasResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - alias.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["content"].IsNullOrEmpty()) + var alias = new CDP4Common.DTO.Alias(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - alias.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the alias {id} is null", alias.Iid); + } + else + { + alias.Content = contentProperty.GetString(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - alias.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + alias.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - alias.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + alias.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isSynonym"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isSynonym"u8, out var isSynonymProperty)) { - alias.IsSynonym = jObject["isSynonym"].ToObject(); + if(isSynonymProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isSynonym property of the alias {id} is null", alias.Iid); + } + else + { + alias.IsSynonym = isSynonymProperty.GetBoolean(); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - alias.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the alias {id} is null", alias.Iid); + } + else + { + alias.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - alias.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the alias {id} is null", alias.Iid); + } + else + { + alias.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - alias.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the alias {id} is null", alias.Iid); + } + else + { + alias.ThingPreference = thingPreferenceProperty.GetString(); + } } return alias; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs index ea01ef656..1ea4589f2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,61 +28,87 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class AndExpressionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.AndExpression FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.AndExpression FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var andExpression = new CDP4Common.DTO.AndExpression(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the AndExpressionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - andExpression.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var andExpression = new CDP4Common.DTO.AndExpression(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - andExpression.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + andExpression.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - andExpression.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + andExpression.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - andExpression.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the andExpression {id} is null", andExpression.Iid); + } + else + { + andExpression.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["term"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("term"u8, out var termProperty) && termProperty.ValueKind != JsonValueKind.Null) { - andExpression.Term.AddRange(jObject["term"].ToObject>()); + foreach(var element in termProperty.EnumerateArray()) + { + andExpression.Term.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - andExpression.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the andExpression {id} is null", andExpression.Iid); + } + else + { + andExpression.ThingPreference = thingPreferenceProperty.GetString(); + } } return andExpression; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs index 25487112d..a7223295e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,151 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ApprovalResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Approval FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var approval = new CDP4Common.DTO.Approval(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ApprovalResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - approval.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var approval = new CDP4Common.DTO.Approval(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - approval.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the approval {id} is null", approval.Iid); + } + else + { + approval.Author = authorProperty.GetGuid(); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - approval.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the approval {id} is null", approval.Iid); + } + else + { + approval.Classification = AnnotationApprovalKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - approval.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the approval {id} is null", approval.Iid); + } + else + { + approval.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - approval.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the approval {id} is null", approval.Iid); + } + else + { + approval.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - approval.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + approval.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - approval.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + approval.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - approval.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the approval {id} is null", approval.Iid); + } + else + { + approval.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - approval.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the approval {id} is null", approval.Iid); + } + else + { + approval.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - approval.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the approval {id} is null", approval.Iid); + } + else + { + approval.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - approval.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the approval {id} is null", approval.Iid); + } + else + { + approval.ThingPreference = thingPreferenceProperty.GetString(); + } } return approval; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs index 80af4fa45..c159b1b55 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,116 +28,193 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ArrayParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var arrayParameterType = new CDP4Common.DTO.ArrayParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ArrayParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - arrayParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var arrayParameterType = new CDP4Common.DTO.ArrayParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + arrayParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + arrayParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["component"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("component"u8, out var componentProperty)) { - arrayParameterType.Component.AddRange(jObject["component"].ToOrderedItemCollection()); + arrayParameterType.Component.AddRange(componentProperty.ToOrderedItemCollection()); } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + arrayParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["dimension"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("dimension"u8, out var dimensionProperty)) { - arrayParameterType.Dimension.AddRange(jObject["dimension"].ToOrderedItemCollection()); + arrayParameterType.Dimension.AddRange(dimensionProperty.ToOrderedItemCollection()); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + arrayParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + arrayParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - arrayParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + arrayParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - arrayParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isFinalized"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isFinalized"u8, out var isFinalizedProperty)) { - arrayParameterType.IsFinalized = jObject["isFinalized"].ToObject(); + if(isFinalizedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isFinalized property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.IsFinalized = isFinalizedProperty.GetBoolean(); + } } - if (!jObject["isTensor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isTensor"u8, out var isTensorProperty)) { - arrayParameterType.IsTensor = jObject["isTensor"].ToObject(); + if(isTensorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isTensor property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.IsTensor = isTensorProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - arrayParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - arrayParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - arrayParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - arrayParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - arrayParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the arrayParameterType {id} is null", arrayParameterType.Iid); + } + else + { + arrayParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return arrayParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs index 12f8f7613..0e4aa3f37 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BinaryNoteResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.BinaryNote FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var binaryNote = new CDP4Common.DTO.BinaryNote(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the BinaryNoteResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - binaryNote.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["caption"].IsNullOrEmpty()) + var binaryNote = new CDP4Common.DTO.BinaryNote(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("caption"u8, out var captionProperty)) { - binaryNote.Caption = jObject["caption"].ToObject(); + if(captionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale caption property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.Caption = captionProperty.GetString(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - binaryNote.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + binaryNote.Category.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - binaryNote.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - binaryNote.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + binaryNote.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - binaryNote.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + binaryNote.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fileType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fileType"u8, out var fileTypeProperty)) { - binaryNote.FileType = jObject["fileType"].ToObject(); + if(fileTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale fileType property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.FileType = fileTypeProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - binaryNote.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - binaryNote.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - binaryNote.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - binaryNote.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - binaryNote.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the binaryNote {id} is null", binaryNote.Iid); + } + else + { + binaryNote.ThingPreference = thingPreferenceProperty.GetString(); + } } return binaryNote; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs index abbc98d50..2f4ce317a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,143 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BinaryRelationshipResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var binaryRelationship = new CDP4Common.DTO.BinaryRelationship(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the BinaryRelationshipResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - binaryRelationship.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var binaryRelationship = new CDP4Common.DTO.BinaryRelationship(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - binaryRelationship.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + binaryRelationship.Category.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - binaryRelationship.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + binaryRelationship.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - binaryRelationship.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + binaryRelationship.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - binaryRelationship.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - binaryRelationship.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - binaryRelationship.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValue"u8, out var parameterValueProperty) && parameterValueProperty.ValueKind != JsonValueKind.Null) { - binaryRelationship.ParameterValue.AddRange(jObject["parameterValue"].ToObject>()); + foreach(var element in parameterValueProperty.EnumerateArray()) + { + binaryRelationship.ParameterValue.Add(element.GetGuid()); + } } - if (!jObject["source"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("source"u8, out var sourceProperty)) { - binaryRelationship.Source = jObject["source"].ToObject(); + if(sourceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale source property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.Source = sourceProperty.GetGuid(); + } } - if (!jObject["target"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("target"u8, out var targetProperty)) { - binaryRelationship.Target = jObject["target"].ToObject(); + if(targetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale target property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.Target = targetProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - binaryRelationship.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the binaryRelationship {id} is null", binaryRelationship.Iid); + } + else + { + binaryRelationship.ThingPreference = thingPreferenceProperty.GetString(); + } } return binaryRelationship; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs index a98ccc863..d27b9cbf7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,199 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BinaryRelationshipRuleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var binaryRelationshipRule = new CDP4Common.DTO.BinaryRelationshipRule(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - binaryRelationshipRule.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the BinaryRelationshipRuleResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["alias"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - binaryRelationshipRule.Alias.AddRange(jObject["alias"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["definition"].IsNullOrEmpty()) + var binaryRelationshipRule = new CDP4Common.DTO.BinaryRelationshipRule(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - binaryRelationshipRule.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + binaryRelationshipRule.Alias.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - binaryRelationshipRule.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + binaryRelationshipRule.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - binaryRelationshipRule.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + binaryRelationshipRule.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["forwardRelationshipName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - binaryRelationshipRule.ForwardRelationshipName = jObject["forwardRelationshipName"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + binaryRelationshipRule.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("forwardRelationshipName"u8, out var forwardRelationshipNameProperty)) { - binaryRelationshipRule.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + if(forwardRelationshipNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale forwardRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.ForwardRelationshipName = forwardRelationshipNameProperty.GetString(); + } } - if (!jObject["inverseRelationshipName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - binaryRelationshipRule.InverseRelationshipName = jObject["inverseRelationshipName"].ToObject(); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + binaryRelationshipRule.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("inverseRelationshipName"u8, out var inverseRelationshipNameProperty)) { - binaryRelationshipRule.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(inverseRelationshipNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale inverseRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.InverseRelationshipName = inverseRelationshipNameProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - binaryRelationshipRule.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - binaryRelationshipRule.Name = jObject["name"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["relationshipCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - binaryRelationshipRule.RelationshipCategory = jObject["relationshipCategory"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relationshipCategory"u8, out var relationshipCategoryProperty)) { - binaryRelationshipRule.ShortName = jObject["shortName"].ToObject(); + if(relationshipCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale relationshipCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.RelationshipCategory = relationshipCategoryProperty.GetGuid(); + } } - if (!jObject["sourceCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - binaryRelationshipRule.SourceCategory = jObject["sourceCategory"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["targetCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceCategory"u8, out var sourceCategoryProperty)) { - binaryRelationshipRule.TargetCategory = jObject["targetCategory"].ToObject(); - } + if(sourceCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale sourceCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.SourceCategory = sourceCategoryProperty.GetGuid(); + } + } + + if (jsonElement.TryGetProperty("targetCategory"u8, out var targetCategoryProperty)) + { + if(targetCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale targetCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.TargetCategory = targetCategoryProperty.GetGuid(); + } + } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - binaryRelationshipRule.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + } + else + { + binaryRelationshipRule.ThingPreference = thingPreferenceProperty.GetString(); + } } return binaryRelationshipRule; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs index de63bcbbd..02a849837 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,140 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BookResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Book FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var book = new CDP4Common.DTO.Book(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the BookResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - book.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var book = new CDP4Common.DTO.Book(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - book.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + book.Category.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - book.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the book {id} is null", book.Iid); + } + else + { + book.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - book.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + book.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - book.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + book.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - book.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the book {id} is null", book.Iid); + } + else + { + book.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - book.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the book {id} is null", book.Iid); + } + else + { + book.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - book.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the book {id} is null", book.Iid); + } + else + { + book.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["section"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("section"u8, out var sectionProperty)) { - book.Section.AddRange(jObject["section"].ToOrderedItemCollection()); + book.Section.AddRange(sectionProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - book.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the book {id} is null", book.Iid); + } + else + { + book.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - book.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the book {id} is null", book.Iid); + } + else + { + book.ThingPreference = thingPreferenceProperty.GetString(); + } } return book; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs index 369e4a6f4..78a4acd3d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BooleanParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var booleanParameterType = new CDP4Common.DTO.BooleanParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the BooleanParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - booleanParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var booleanParameterType = new CDP4Common.DTO.BooleanParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + booleanParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + booleanParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + booleanParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + booleanParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + booleanParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - booleanParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + booleanParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - booleanParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - booleanParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - booleanParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - booleanParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - booleanParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - booleanParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the booleanParameterType {id} is null", booleanParameterType.Iid); + } + else + { + booleanParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return booleanParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs index ce8640827..040a11bd0 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BoundsResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Bounds FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var bounds = new CDP4Common.DTO.Bounds(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the BoundsResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - bounds.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var bounds = new CDP4Common.DTO.Bounds(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - bounds.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + bounds.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - bounds.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + bounds.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["height"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("height"u8, out var heightProperty)) { - bounds.Height = jObject["height"].ToObject(); + if(heightProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale height property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.Height = heightProperty.GetSingle(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - bounds.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - bounds.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - bounds.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["width"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("width"u8, out var widthProperty)) { - bounds.Width = jObject["width"].ToObject(); + if(widthProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale width property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.Width = widthProperty.GetSingle(); + } } - if (!jObject["x"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("x"u8, out var xProperty)) { - bounds.X = jObject["x"].ToObject(); + if(xProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale x property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.X = xProperty.GetSingle(); + } } - if (!jObject["y"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("y"u8, out var yProperty)) { - bounds.Y = jObject["y"].ToObject(); + if(yProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale y property of the bounds {id} is null", bounds.Iid); + } + else + { + bounds.Y = yProperty.GetSingle(); + } } return bounds; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs index 474cbd6c6..e86891285 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class BuiltInRuleVerificationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var builtInRuleVerification = new CDP4Common.DTO.BuiltInRuleVerification(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - builtInRuleVerification.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the BuiltInRuleVerificationResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - builtInRuleVerification.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var builtInRuleVerification = new CDP4Common.DTO.BuiltInRuleVerification(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - builtInRuleVerification.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + builtInRuleVerification.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["executedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - builtInRuleVerification.ExecutedOn = jObject["executedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + builtInRuleVerification.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isActive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("executedOn"u8, out var executedOnProperty)) { - builtInRuleVerification.IsActive = jObject["isActive"].ToObject(); + if(executedOnProperty.ValueKind == JsonValueKind.Null) + { + builtInRuleVerification.ExecutedOn = null; + } + else + { + builtInRuleVerification.ExecutedOn = executedOnProperty.GetDateTime(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isActive"u8, out var isActiveProperty)) { - builtInRuleVerification.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(isActiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isActive property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + } + else + { + builtInRuleVerification.IsActive = isActiveProperty.GetBoolean(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - builtInRuleVerification.Name = jObject["name"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + } + else + { + builtInRuleVerification.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - builtInRuleVerification.Status = jObject["status"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + } + else + { + builtInRuleVerification.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - builtInRuleVerification.ThingPreference = jObject["thingPreference"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + } + else + { + builtInRuleVerification.Status = RuleVerificationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["violation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - builtInRuleVerification.Violation.AddRange(jObject["violation"].ToObject>()); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + } + else + { + builtInRuleVerification.ThingPreference = thingPreferenceProperty.GetString(); + } } return builtInRuleVerification; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs index 660ad2650..babc936ae 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,167 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class CategoryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Category FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var category = new CDP4Common.DTO.Category(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the CategoryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - category.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var category = new CDP4Common.DTO.Category(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - category.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + category.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - category.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + category.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - category.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + category.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - category.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + category.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - category.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + category.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isAbstract"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isAbstract"u8, out var isAbstractProperty)) { - category.IsAbstract = jObject["isAbstract"].ToObject(); + if(isAbstractProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isAbstract property of the category {id} is null", category.Iid); + } + else + { + category.IsAbstract = isAbstractProperty.GetBoolean(); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - category.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the category {id} is null", category.Iid); + } + else + { + category.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - category.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the category {id} is null", category.Iid); + } + else + { + category.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - category.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the category {id} is null", category.Iid); + } + else + { + category.Name = nameProperty.GetString(); + } } - if (!jObject["permissibleClass"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("permissibleClass"u8, out var permissibleClassProperty) && permissibleClassProperty.ValueKind != JsonValueKind.Null) { - category.PermissibleClass.AddRange(jObject["permissibleClass"].ToObject>()); + foreach(var element in permissibleClassProperty.EnumerateArray()) + { + category.PermissibleClass.Add(ClassKindDeserializer.Deserialize(element)); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - category.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the category {id} is null", category.Iid); + } + else + { + category.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["superCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("superCategory"u8, out var superCategoryProperty) && superCategoryProperty.ValueKind != JsonValueKind.Null) { - category.SuperCategory.AddRange(jObject["superCategory"].ToObject>()); + foreach(var element in superCategoryProperty.EnumerateArray()) + { + category.SuperCategory.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - category.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the category {id} is null", category.Iid); + } + else + { + category.ThingPreference = thingPreferenceProperty.GetString(); + } } return category; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs index 3bb8d36cc..fae894ee8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,136 +28,251 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ChangeProposalResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ChangeProposal FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var changeProposal = new CDP4Common.DTO.ChangeProposal(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ChangeProposalResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - changeProposal.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var changeProposal = new CDP4Common.DTO.ChangeProposal(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - changeProposal.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + changeProposal.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - changeProposal.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - changeProposal.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + changeProposal.Category.Add(element.GetGuid()); + } } - if (!jObject["changeRequest"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("changeRequest"u8, out var changeRequestProperty)) { - changeProposal.ChangeRequest = jObject["changeRequest"].ToObject(); + if(changeRequestProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale changeRequest property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.ChangeRequest = changeRequestProperty.GetGuid(); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - changeProposal.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - changeProposal.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - changeProposal.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - changeProposal.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + changeProposal.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - changeProposal.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + changeProposal.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - changeProposal.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + changeProposal.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - changeProposal.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - changeProposal.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - changeProposal.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - changeProposal.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + changeProposal.PrimaryAnnotatedThing = null; + } + else + { + changeProposal.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - changeProposal.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + changeProposal.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - changeProposal.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - changeProposal.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + changeProposal.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - changeProposal.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - changeProposal.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - changeProposal.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the changeProposal {id} is null", changeProposal.Iid); + } + else + { + changeProposal.Title = titleProperty.GetString(); + } } return changeProposal; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs index 39d40aea3..e7cd93b16 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,131 +28,239 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ChangeRequestResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ChangeRequest FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var changeRequest = new CDP4Common.DTO.ChangeRequest(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ChangeRequestResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - changeRequest.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var changeRequest = new CDP4Common.DTO.ChangeRequest(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - changeRequest.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + changeRequest.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - changeRequest.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - changeRequest.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + changeRequest.Category.Add(element.GetGuid()); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - changeRequest.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - changeRequest.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - changeRequest.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - changeRequest.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + changeRequest.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - changeRequest.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + changeRequest.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - changeRequest.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + changeRequest.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - changeRequest.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - changeRequest.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - changeRequest.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - changeRequest.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + changeRequest.PrimaryAnnotatedThing = null; + } + else + { + changeRequest.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - changeRequest.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + changeRequest.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - changeRequest.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - changeRequest.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + changeRequest.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - changeRequest.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - changeRequest.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - changeRequest.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the changeRequest {id} is null", changeRequest.Iid); + } + else + { + changeRequest.Title = titleProperty.GetString(); + } } return changeRequest; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs index f26d8aa6f..7d4b2e3bd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class CitationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Citation FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var citation = new CDP4Common.DTO.Citation(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the CitationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - citation.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var citation = new CDP4Common.DTO.Citation(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - citation.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + citation.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - citation.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + citation.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isAdaptation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isAdaptation"u8, out var isAdaptationProperty)) { - citation.IsAdaptation = jObject["isAdaptation"].ToObject(); + if(isAdaptationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isAdaptation property of the citation {id} is null", citation.Iid); + } + else + { + citation.IsAdaptation = isAdaptationProperty.GetBoolean(); + } } - if (!jObject["location"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("location"u8, out var locationProperty)) { - citation.Location = jObject["location"].ToObject(); + if(locationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale location property of the citation {id} is null", citation.Iid); + } + else + { + citation.Location = locationProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - citation.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the citation {id} is null", citation.Iid); + } + else + { + citation.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["remark"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("remark"u8, out var remarkProperty)) { - citation.Remark = jObject["remark"].ToObject(); + if(remarkProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale remark property of the citation {id} is null", citation.Iid); + } + else + { + citation.Remark = remarkProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - citation.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the citation {id} is null", citation.Iid); + } + else + { + citation.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["source"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("source"u8, out var sourceProperty)) { - citation.Source = jObject["source"].ToObject(); + if(sourceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale source property of the citation {id} is null", citation.Iid); + } + else + { + citation.Source = sourceProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - citation.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the citation {id} is null", citation.Iid); + } + else + { + citation.ThingPreference = thingPreferenceProperty.GetString(); + } } return citation; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs index 187ad15ca..10ad217a9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ColorResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Color FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var color = new CDP4Common.DTO.Color(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ColorResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - color.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["blue"].IsNullOrEmpty()) + var color = new CDP4Common.DTO.Color(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("blue"u8, out var blueProperty)) { - color.Blue = jObject["blue"].ToObject(); + if(blueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale blue property of the color {id} is null", color.Iid); + } + else + { + color.Blue = blueProperty.GetInt32(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - color.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + color.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - color.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + color.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["green"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("green"u8, out var greenProperty)) { - color.Green = jObject["green"].ToObject(); + if(greenProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale green property of the color {id} is null", color.Iid); + } + else + { + color.Green = greenProperty.GetInt32(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - color.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the color {id} is null", color.Iid); + } + else + { + color.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - color.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the color {id} is null", color.Iid); + } + else + { + color.Name = nameProperty.GetString(); + } } - if (!jObject["red"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("red"u8, out var redProperty)) { - color.Red = jObject["red"].ToObject(); + if(redProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale red property of the color {id} is null", color.Iid); + } + else + { + color.Red = redProperty.GetInt32(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - color.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the color {id} is null", color.Iid); + } + else + { + color.ThingPreference = thingPreferenceProperty.GetString(); + } } return color; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs index c908c9a85..0b18fb310 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,131 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class CommonFileStoreResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.CommonFileStore FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var commonFileStore = new CDP4Common.DTO.CommonFileStore(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the CommonFileStoreResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - commonFileStore.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["createdOn"].IsNullOrEmpty()) + var commonFileStore = new CDP4Common.DTO.CommonFileStore(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - commonFileStore.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the commonFileStore {id} is null", commonFileStore.Iid); + } + else + { + commonFileStore.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - commonFileStore.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + commonFileStore.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - commonFileStore.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + commonFileStore.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["file"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("file"u8, out var fileProperty) && fileProperty.ValueKind != JsonValueKind.Null) { - commonFileStore.File.AddRange(jObject["file"].ToObject>()); + foreach(var element in fileProperty.EnumerateArray()) + { + commonFileStore.File.Add(element.GetGuid()); + } } - if (!jObject["folder"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("folder"u8, out var folderProperty) && folderProperty.ValueKind != JsonValueKind.Null) { - commonFileStore.Folder.AddRange(jObject["folder"].ToObject>()); + foreach(var element in folderProperty.EnumerateArray()) + { + commonFileStore.Folder.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - commonFileStore.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the commonFileStore {id} is null", commonFileStore.Iid); + } + else + { + commonFileStore.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - commonFileStore.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the commonFileStore {id} is null", commonFileStore.Iid); + } + else + { + commonFileStore.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - commonFileStore.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the commonFileStore {id} is null", commonFileStore.Iid); + } + else + { + commonFileStore.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - commonFileStore.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the commonFileStore {id} is null", commonFileStore.Iid); + } + else + { + commonFileStore.ThingPreference = thingPreferenceProperty.GetString(); + } } return commonFileStore; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs index 6eb3f16bf..565b835c6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,176 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class CompoundParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var compoundParameterType = new CDP4Common.DTO.CompoundParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the CompoundParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - compoundParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var compoundParameterType = new CDP4Common.DTO.CompoundParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + compoundParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + compoundParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["component"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("component"u8, out var componentProperty)) { - compoundParameterType.Component.AddRange(jObject["component"].ToOrderedItemCollection()); + compoundParameterType.Component.AddRange(componentProperty.ToOrderedItemCollection()); } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + compoundParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + compoundParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + compoundParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - compoundParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + compoundParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - compoundParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isFinalized"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isFinalized"u8, out var isFinalizedProperty)) { - compoundParameterType.IsFinalized = jObject["isFinalized"].ToObject(); + if(isFinalizedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isFinalized property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.IsFinalized = isFinalizedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - compoundParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - compoundParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - compoundParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - compoundParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - compoundParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the compoundParameterType {id} is null", compoundParameterType.Iid); + } + else + { + compoundParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return compoundParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs index 282c63007..c3219160a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,175 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ConstantResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Constant FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var constant = new CDP4Common.DTO.Constant(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - constant.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the ConstantResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["alias"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - constant.Alias.AddRange(jObject["alias"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var constant = new CDP4Common.DTO.Constant(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - constant.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + constant.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - constant.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + constant.Category.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - constant.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + constant.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - constant.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + constant.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - constant.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + constant.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - constant.IsDeprecated = jObject["isDeprecated"].ToObject(); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + constant.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - constant.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the constant {id} is null", constant.Iid); + } + else + { + constant.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - constant.Name = jObject["name"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the constant {id} is null", constant.Iid); + } + else + { + constant.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - constant.ParameterType = jObject["parameterType"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the constant {id} is null", constant.Iid); + } + else + { + constant.Name = nameProperty.GetString(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - constant.Scale = jObject["scale"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the constant {id} is null", constant.Iid); + } + else + { + constant.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - constant.ShortName = jObject["shortName"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + constant.Scale = null; + } + else + { + constant.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - constant.ThingPreference = jObject["thingPreference"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the constant {id} is null", constant.Iid); + } + else + { + constant.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) + { + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the constant {id} is null", constant.Iid); + } + else + { + constant.ThingPreference = thingPreferenceProperty.GetString(); + } + } + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - constant.Value = SerializerHelper.ToValueArray(jObject["value"].ToString()); + constant.Value = SerializerHelper.ToValueArray(valueProperty.GetString()); } return constant; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs index dffd7f9fb..b4aa0b635 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,136 +28,251 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ContractChangeNoticeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var contractChangeNotice = new CDP4Common.DTO.ContractChangeNotice(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ContractChangeNoticeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - contractChangeNotice.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var contractChangeNotice = new CDP4Common.DTO.ContractChangeNotice(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + contractChangeNotice.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - contractChangeNotice.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + contractChangeNotice.Category.Add(element.GetGuid()); + } } - if (!jObject["changeProposal"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("changeProposal"u8, out var changeProposalProperty)) { - contractChangeNotice.ChangeProposal = jObject["changeProposal"].ToObject(); + if(changeProposalProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale changeProposal property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.ChangeProposal = changeProposalProperty.GetGuid(); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - contractChangeNotice.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - contractChangeNotice.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - contractChangeNotice.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + contractChangeNotice.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + contractChangeNotice.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + contractChangeNotice.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - contractChangeNotice.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - contractChangeNotice.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - contractChangeNotice.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - contractChangeNotice.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + contractChangeNotice.PrimaryAnnotatedThing = null; + } + else + { + contractChangeNotice.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + contractChangeNotice.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - contractChangeNotice.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - contractChangeNotice.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + contractChangeNotice.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - contractChangeNotice.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - contractChangeNotice.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - contractChangeNotice.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + } + else + { + contractChangeNotice.Title = titleProperty.GetString(); + } } return contractChangeNotice; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs index b9a51d584..e479477f8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,141 +28,263 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class CyclicRatioScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var cyclicRatioScale = new CDP4Common.DTO.CyclicRatioScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the CyclicRatioScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - cyclicRatioScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var cyclicRatioScale = new CDP4Common.DTO.CyclicRatioScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + cyclicRatioScale.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + cyclicRatioScale.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + cyclicRatioScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + cyclicRatioScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + cyclicRatioScale.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - cyclicRatioScale.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isMaximumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMaximumInclusive"u8, out var isMaximumInclusiveProperty)) { - cyclicRatioScale.IsMaximumInclusive = jObject["isMaximumInclusive"].ToObject(); + if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMaximumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.IsMaximumInclusive = isMaximumInclusiveProperty.GetBoolean(); + } } - if (!jObject["isMinimumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMinimumInclusive"u8, out var isMinimumInclusiveProperty)) { - cyclicRatioScale.IsMinimumInclusive = jObject["isMinimumInclusive"].ToObject(); + if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMinimumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.IsMinimumInclusive = isMinimumInclusiveProperty.GetBoolean(); + } } - if (!jObject["mappingToReferenceScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("mappingToReferenceScale"u8, out var mappingToReferenceScaleProperty) && mappingToReferenceScaleProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.MappingToReferenceScale.AddRange(jObject["mappingToReferenceScale"].ToObject>()); + foreach(var element in mappingToReferenceScaleProperty.EnumerateArray()) + { + cyclicRatioScale.MappingToReferenceScale.Add(element.GetGuid()); + } } - if (!jObject["maximumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maximumPermissibleValue"u8, out var maximumPermissibleValueProperty)) { - cyclicRatioScale.MaximumPermissibleValue = jObject["maximumPermissibleValue"].ToObject(); + if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maximumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.MaximumPermissibleValue = maximumPermissibleValueProperty.GetString(); + } } - if (!jObject["minimumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minimumPermissibleValue"u8, out var minimumPermissibleValueProperty)) { - cyclicRatioScale.MinimumPermissibleValue = jObject["minimumPermissibleValue"].ToObject(); + if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minimumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.MinimumPermissibleValue = minimumPermissibleValueProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - cyclicRatioScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["modulus"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modulus"u8, out var modulusProperty)) { - cyclicRatioScale.Modulus = jObject["modulus"].ToObject(); + if(modulusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modulus property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.Modulus = modulusProperty.GetString(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - cyclicRatioScale.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.Name = nameProperty.GetString(); + } } - if (!jObject["negativeValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("negativeValueConnotation"u8, out var negativeValueConnotationProperty)) { - cyclicRatioScale.NegativeValueConnotation = jObject["negativeValueConnotation"].ToObject(); + if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale negativeValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.NegativeValueConnotation = negativeValueConnotationProperty.GetString(); + } } - if (!jObject["numberSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("numberSet"u8, out var numberSetProperty)) { - cyclicRatioScale.NumberSet = jObject["numberSet"].ToObject(); + if(numberSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale numberSet property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.NumberSet = NumberSetKindDeserializer.Deserialize(numberSetProperty); + } } - if (!jObject["positiveValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("positiveValueConnotation"u8, out var positiveValueConnotationProperty)) { - cyclicRatioScale.PositiveValueConnotation = jObject["positiveValueConnotation"].ToObject(); + if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale positiveValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.PositiveValueConnotation = positiveValueConnotationProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - cyclicRatioScale.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - cyclicRatioScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - cyclicRatioScale.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + } + else + { + cyclicRatioScale.Unit = unitProperty.GetGuid(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty) && valueDefinitionProperty.ValueKind != JsonValueKind.Null) { - cyclicRatioScale.ValueDefinition.AddRange(jObject["valueDefinition"].ToObject>()); + foreach(var element in valueDefinitionProperty.EnumerateArray()) + { + cyclicRatioScale.ValueDefinition.Add(element.GetGuid()); + } } return cyclicRatioScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs index 964d4dc10..cedfd804c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DateParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DateParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var dateParameterType = new CDP4Common.DTO.DateParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DateParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - dateParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var dateParameterType = new CDP4Common.DTO.DateParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + dateParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + dateParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + dateParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + dateParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + dateParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - dateParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + dateParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - dateParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - dateParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - dateParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - dateParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - dateParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - dateParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the dateParameterType {id} is null", dateParameterType.Iid); + } + else + { + dateParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return dateParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs index 5e06047d3..397201bff 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DateTimeParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var dateTimeParameterType = new CDP4Common.DTO.DateTimeParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DateTimeParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - dateTimeParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var dateTimeParameterType = new CDP4Common.DTO.DateTimeParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + dateTimeParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + dateTimeParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + dateTimeParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + dateTimeParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + dateTimeParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - dateTimeParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + dateTimeParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - dateTimeParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - dateTimeParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - dateTimeParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - dateTimeParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - dateTimeParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - dateTimeParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + } + else + { + dateTimeParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return dateTimeParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs index 525a3d409..840efd27d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,183 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DecompositionRuleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DecompositionRule FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var decompositionRule = new CDP4Common.DTO.DecompositionRule(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DecompositionRuleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - decompositionRule.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var decompositionRule = new CDP4Common.DTO.DecompositionRule(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + decompositionRule.Alias.Add(element.GetGuid()); + } } - if (!jObject["containedCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("containedCategory"u8, out var containedCategoryProperty) && containedCategoryProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.ContainedCategory.AddRange(jObject["containedCategory"].ToObject>()); + foreach(var element in containedCategoryProperty.EnumerateArray()) + { + decompositionRule.ContainedCategory.Add(element.GetGuid()); + } } - if (!jObject["containingCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("containingCategory"u8, out var containingCategoryProperty)) { - decompositionRule.ContainingCategory = jObject["containingCategory"].ToObject(); + if(containingCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale containingCategory property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.ContainingCategory = containingCategoryProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + decompositionRule.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + decompositionRule.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + decompositionRule.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - decompositionRule.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + decompositionRule.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - decompositionRule.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["maxContained"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maxContained"u8, out var maxContainedProperty)) { - decompositionRule.MaxContained = jObject["maxContained"].ToObject(); + if(maxContainedProperty.ValueKind == JsonValueKind.Null) + { + decompositionRule.MaxContained = null; + } + else + { + decompositionRule.MaxContained = maxContainedProperty.GetInt32(); + } } - if (!jObject["minContained"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minContained"u8, out var minContainedProperty)) { - decompositionRule.MinContained = jObject["minContained"].ToObject(); + if(minContainedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minContained property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.MinContained = minContainedProperty.GetInt32(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - decompositionRule.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - decompositionRule.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - decompositionRule.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - decompositionRule.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the decompositionRule {id} is null", decompositionRule.Iid); + } + else + { + decompositionRule.ThingPreference = thingPreferenceProperty.GetString(); + } } return decompositionRule; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs index 4fe20140d..9a90885b1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,121 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DefinitionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Definition FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Definition FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var definition = new CDP4Common.DTO.Definition(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DefinitionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - definition.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["citation"].IsNullOrEmpty()) + var definition = new CDP4Common.DTO.Definition(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("citation"u8, out var citationProperty) && citationProperty.ValueKind != JsonValueKind.Null) { - definition.Citation.AddRange(jObject["citation"].ToObject>()); + foreach(var element in citationProperty.EnumerateArray()) + { + definition.Citation.Add(element.GetGuid()); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - definition.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the definition {id} is null", definition.Iid); + } + else + { + definition.Content = contentProperty.GetString(); + } } - if (!jObject["example"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("example"u8, out var exampleProperty)) { - definition.Example.AddRange(jObject["example"].ToOrderedItemCollection()); + definition.Example.AddRange(exampleProperty.ToOrderedItemCollection()); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - definition.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + definition.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - definition.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + definition.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - definition.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the definition {id} is null", definition.Iid); + } + else + { + definition.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - definition.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the definition {id} is null", definition.Iid); + } + else + { + definition.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["note"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("note"u8, out var noteProperty)) { - definition.Note.AddRange(jObject["note"].ToOrderedItemCollection()); + definition.Note.AddRange(noteProperty.ToOrderedItemCollection()); } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - definition.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the definition {id} is null", definition.Iid); + } + else + { + definition.ThingPreference = thingPreferenceProperty.GetString(); + } } return definition; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs index 26f651b42..b424f62a8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DependentParameterTypeAssignmentResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DependentParameterTypeAssignment FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DependentParameterTypeAssignment FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var dependentParameterTypeAssignment = new CDP4Common.DTO.DependentParameterTypeAssignment(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DependentParameterTypeAssignmentResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - dependentParameterTypeAssignment.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var dependentParameterTypeAssignment = new CDP4Common.DTO.DependentParameterTypeAssignment(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - dependentParameterTypeAssignment.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + dependentParameterTypeAssignment.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - dependentParameterTypeAssignment.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + dependentParameterTypeAssignment.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["measurementScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("measurementScale"u8, out var measurementScaleProperty)) { - dependentParameterTypeAssignment.MeasurementScale = jObject["measurementScale"].ToObject(); + if(measurementScaleProperty.ValueKind == JsonValueKind.Null) + { + dependentParameterTypeAssignment.MeasurementScale = null; + } + else + { + dependentParameterTypeAssignment.MeasurementScale = measurementScaleProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - dependentParameterTypeAssignment.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + } + else + { + dependentParameterTypeAssignment.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - dependentParameterTypeAssignment.ParameterType = jObject["parameterType"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + } + else + { + dependentParameterTypeAssignment.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - dependentParameterTypeAssignment.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + } + else + { + dependentParameterTypeAssignment.ThingPreference = thingPreferenceProperty.GetString(); + } } return dependentParameterTypeAssignment; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs index 83c4c7fdd..351ed6f2a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,116 +28,196 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DerivedQuantityKindResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var derivedQuantityKind = new CDP4Common.DTO.DerivedQuantityKind(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DerivedQuantityKindResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - derivedQuantityKind.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var derivedQuantityKind = new CDP4Common.DTO.DerivedQuantityKind(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + derivedQuantityKind.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + derivedQuantityKind.Category.Add(element.GetGuid()); + } } - if (!jObject["defaultScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultScale"u8, out var defaultScaleProperty)) { - derivedQuantityKind.DefaultScale = jObject["defaultScale"].ToObject(); + if(defaultScaleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale defaultScale property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.DefaultScale = defaultScaleProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + derivedQuantityKind.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + derivedQuantityKind.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + derivedQuantityKind.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + derivedQuantityKind.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - derivedQuantityKind.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - derivedQuantityKind.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - derivedQuantityKind.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.Name = nameProperty.GetString(); + } } - if (!jObject["possibleScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleScale"u8, out var possibleScaleProperty) && possibleScaleProperty.ValueKind != JsonValueKind.Null) { - derivedQuantityKind.PossibleScale.AddRange(jObject["possibleScale"].ToObject>()); + foreach(var element in possibleScaleProperty.EnumerateArray()) + { + derivedQuantityKind.PossibleScale.Add(element.GetGuid()); + } } - if (!jObject["quantityDimensionSymbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("quantityDimensionSymbol"u8, out var quantityDimensionSymbolProperty)) { - derivedQuantityKind.QuantityDimensionSymbol = jObject["quantityDimensionSymbol"].ToObject(); + if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale quantityDimensionSymbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.QuantityDimensionSymbol = quantityDimensionSymbolProperty.GetString(); + } } - if (!jObject["quantityKindFactor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("quantityKindFactor"u8, out var quantityKindFactorProperty)) { - derivedQuantityKind.QuantityKindFactor.AddRange(jObject["quantityKindFactor"].ToOrderedItemCollection()); + derivedQuantityKind.QuantityKindFactor.AddRange(quantityKindFactorProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - derivedQuantityKind.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - derivedQuantityKind.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - derivedQuantityKind.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + } + else + { + derivedQuantityKind.ThingPreference = thingPreferenceProperty.GetString(); + } } return derivedQuantityKind; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs index 3a55dcad1..843692006 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,144 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DerivedUnitResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DerivedUnit FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var derivedUnit = new CDP4Common.DTO.DerivedUnit(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DerivedUnitResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - derivedUnit.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var derivedUnit = new CDP4Common.DTO.DerivedUnit(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - derivedUnit.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + derivedUnit.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - derivedUnit.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + derivedUnit.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - derivedUnit.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + derivedUnit.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - derivedUnit.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + derivedUnit.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - derivedUnit.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + derivedUnit.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - derivedUnit.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the derivedUnit {id} is null", derivedUnit.Iid); + } + else + { + derivedUnit.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - derivedUnit.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the derivedUnit {id} is null", derivedUnit.Iid); + } + else + { + derivedUnit.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - derivedUnit.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the derivedUnit {id} is null", derivedUnit.Iid); + } + else + { + derivedUnit.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - derivedUnit.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the derivedUnit {id} is null", derivedUnit.Iid); + } + else + { + derivedUnit.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - derivedUnit.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the derivedUnit {id} is null", derivedUnit.Iid); + } + else + { + derivedUnit.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unitFactor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unitFactor"u8, out var unitFactorProperty)) { - derivedUnit.UnitFactor.AddRange(jObject["unitFactor"].ToOrderedItemCollection()); + derivedUnit.UnitFactor.AddRange(unitFactorProperty.ToOrderedItemCollection()); } return derivedUnit; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs index a42335a3a..eb1f7514d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,119 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DiagramCanvasResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var diagramCanvas = new CDP4Common.DTO.DiagramCanvas(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DiagramCanvasResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - diagramCanvas.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["bounds"].IsNullOrEmpty()) + var diagramCanvas = new CDP4Common.DTO.DiagramCanvas(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("bounds"u8, out var boundsProperty) && boundsProperty.ValueKind != JsonValueKind.Null) { - diagramCanvas.Bounds.AddRange(jObject["bounds"].ToObject>()); + foreach(var element in boundsProperty.EnumerateArray()) + { + diagramCanvas.Bounds.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - diagramCanvas.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); + } + else + { + diagramCanvas.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["diagramElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("diagramElement"u8, out var diagramElementProperty) && diagramElementProperty.ValueKind != JsonValueKind.Null) { - diagramCanvas.DiagramElement.AddRange(jObject["diagramElement"].ToObject>()); + foreach(var element in diagramElementProperty.EnumerateArray()) + { + diagramCanvas.DiagramElement.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - diagramCanvas.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + diagramCanvas.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - diagramCanvas.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + diagramCanvas.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - diagramCanvas.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); + } + else + { + diagramCanvas.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - diagramCanvas.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the diagramCanvas {id} is null", diagramCanvas.Iid); + } + else + { + diagramCanvas.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - diagramCanvas.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the diagramCanvas {id} is null", diagramCanvas.Iid); + } + else + { + diagramCanvas.ThingPreference = thingPreferenceProperty.GetString(); + } } return diagramCanvas; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs index 1ade8376c..c5e8aff11 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,168 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DiagramEdgeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DiagramEdge FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var diagramEdge = new CDP4Common.DTO.DiagramEdge(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DiagramEdgeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - diagramEdge.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["bounds"].IsNullOrEmpty()) + var diagramEdge = new CDP4Common.DTO.DiagramEdge(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("bounds"u8, out var boundsProperty) && boundsProperty.ValueKind != JsonValueKind.Null) { - diagramEdge.Bounds.AddRange(jObject["bounds"].ToObject>()); + foreach(var element in boundsProperty.EnumerateArray()) + { + diagramEdge.Bounds.Add(element.GetGuid()); + } } - if (!jObject["depictedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("depictedThing"u8, out var depictedThingProperty)) { - diagramEdge.DepictedThing = jObject["depictedThing"].ToObject(); + if(depictedThingProperty.ValueKind == JsonValueKind.Null) + { + diagramEdge.DepictedThing = null; + } + else + { + diagramEdge.DepictedThing = depictedThingProperty.GetGuid(); + } } - if (!jObject["diagramElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("diagramElement"u8, out var diagramElementProperty) && diagramElementProperty.ValueKind != JsonValueKind.Null) { - diagramEdge.DiagramElement.AddRange(jObject["diagramElement"].ToObject>()); + foreach(var element in diagramElementProperty.EnumerateArray()) + { + diagramEdge.DiagramElement.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - diagramEdge.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + diagramEdge.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - diagramEdge.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + diagramEdge.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["localStyle"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("localStyle"u8, out var localStyleProperty) && localStyleProperty.ValueKind != JsonValueKind.Null) { - diagramEdge.LocalStyle.AddRange(jObject["localStyle"].ToObject>()); + foreach(var element in localStyleProperty.EnumerateArray()) + { + diagramEdge.LocalStyle.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - diagramEdge.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the diagramEdge {id} is null", diagramEdge.Iid); + } + else + { + diagramEdge.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - diagramEdge.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the diagramEdge {id} is null", diagramEdge.Iid); + } + else + { + diagramEdge.Name = nameProperty.GetString(); + } } - if (!jObject["point"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("point"u8, out var pointProperty)) { - diagramEdge.Point.AddRange(jObject["point"].ToOrderedItemCollection()); + diagramEdge.Point.AddRange(pointProperty.ToOrderedItemCollection()); } - if (!jObject["sharedStyle"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sharedStyle"u8, out var sharedStyleProperty)) { - diagramEdge.SharedStyle = jObject["sharedStyle"].ToObject(); + if(sharedStyleProperty.ValueKind == JsonValueKind.Null) + { + diagramEdge.SharedStyle = null; + } + else + { + diagramEdge.SharedStyle = sharedStyleProperty.GetGuid(); + } } - if (!jObject["source"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("source"u8, out var sourceProperty)) { - diagramEdge.Source = jObject["source"].ToObject(); + if(sourceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale source property of the diagramEdge {id} is null", diagramEdge.Iid); + } + else + { + diagramEdge.Source = sourceProperty.GetGuid(); + } } - if (!jObject["target"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("target"u8, out var targetProperty)) { - diagramEdge.Target = jObject["target"].ToObject(); + if(targetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale target property of the diagramEdge {id} is null", diagramEdge.Iid); + } + else + { + diagramEdge.Target = targetProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - diagramEdge.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the diagramEdge {id} is null", diagramEdge.Iid); + } + else + { + diagramEdge.ThingPreference = thingPreferenceProperty.GetString(); + } } return diagramEdge; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs index 7569ca9ba..be0d77768 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,163 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DiagramObjectResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DiagramObject FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var diagramObject = new CDP4Common.DTO.DiagramObject(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DiagramObjectResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - diagramObject.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["bounds"].IsNullOrEmpty()) + var diagramObject = new CDP4Common.DTO.DiagramObject(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("bounds"u8, out var boundsProperty) && boundsProperty.ValueKind != JsonValueKind.Null) { - diagramObject.Bounds.AddRange(jObject["bounds"].ToObject>()); + foreach(var element in boundsProperty.EnumerateArray()) + { + diagramObject.Bounds.Add(element.GetGuid()); + } } - if (!jObject["depictedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("depictedThing"u8, out var depictedThingProperty)) { - diagramObject.DepictedThing = jObject["depictedThing"].ToObject(); + if(depictedThingProperty.ValueKind == JsonValueKind.Null) + { + diagramObject.DepictedThing = null; + } + else + { + diagramObject.DepictedThing = depictedThingProperty.GetGuid(); + } } - if (!jObject["diagramElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("diagramElement"u8, out var diagramElementProperty) && diagramElementProperty.ValueKind != JsonValueKind.Null) { - diagramObject.DiagramElement.AddRange(jObject["diagramElement"].ToObject>()); + foreach(var element in diagramElementProperty.EnumerateArray()) + { + diagramObject.DiagramElement.Add(element.GetGuid()); + } } - if (!jObject["documentation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("documentation"u8, out var documentationProperty)) { - diagramObject.Documentation = jObject["documentation"].ToObject(); + if(documentationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale documentation property of the diagramObject {id} is null", diagramObject.Iid); + } + else + { + diagramObject.Documentation = documentationProperty.GetString(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - diagramObject.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + diagramObject.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - diagramObject.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + diagramObject.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["localStyle"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("localStyle"u8, out var localStyleProperty) && localStyleProperty.ValueKind != JsonValueKind.Null) { - diagramObject.LocalStyle.AddRange(jObject["localStyle"].ToObject>()); + foreach(var element in localStyleProperty.EnumerateArray()) + { + diagramObject.LocalStyle.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - diagramObject.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the diagramObject {id} is null", diagramObject.Iid); + } + else + { + diagramObject.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - diagramObject.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the diagramObject {id} is null", diagramObject.Iid); + } + else + { + diagramObject.Name = nameProperty.GetString(); + } } - if (!jObject["resolution"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("resolution"u8, out var resolutionProperty)) { - diagramObject.Resolution = jObject["resolution"].ToObject(); + if(resolutionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale resolution property of the diagramObject {id} is null", diagramObject.Iid); + } + else + { + diagramObject.Resolution = resolutionProperty.GetSingle(); + } } - if (!jObject["sharedStyle"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sharedStyle"u8, out var sharedStyleProperty)) { - diagramObject.SharedStyle = jObject["sharedStyle"].ToObject(); + if(sharedStyleProperty.ValueKind == JsonValueKind.Null) + { + diagramObject.SharedStyle = null; + } + else + { + diagramObject.SharedStyle = sharedStyleProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - diagramObject.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the diagramObject {id} is null", diagramObject.Iid); + } + else + { + diagramObject.ThingPreference = thingPreferenceProperty.GetString(); + } } return diagramObject; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs index 86f060cae..5c95e266f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,143 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DomainFileStoreResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DomainFileStore FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var domainFileStore = new CDP4Common.DTO.DomainFileStore(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DomainFileStoreResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - domainFileStore.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["createdOn"].IsNullOrEmpty()) + var domainFileStore = new CDP4Common.DTO.DomainFileStore(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - domainFileStore.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - domainFileStore.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + domainFileStore.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - domainFileStore.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + domainFileStore.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["file"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("file"u8, out var fileProperty) && fileProperty.ValueKind != JsonValueKind.Null) { - domainFileStore.File.AddRange(jObject["file"].ToObject>()); + foreach(var element in fileProperty.EnumerateArray()) + { + domainFileStore.File.Add(element.GetGuid()); + } } - if (!jObject["folder"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("folder"u8, out var folderProperty) && folderProperty.ValueKind != JsonValueKind.Null) { - domainFileStore.Folder.AddRange(jObject["folder"].ToObject>()); + foreach(var element in folderProperty.EnumerateArray()) + { + domainFileStore.Folder.Add(element.GetGuid()); + } } - if (!jObject["isHidden"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isHidden"u8, out var isHiddenProperty)) { - domainFileStore.IsHidden = jObject["isHidden"].ToObject(); + if(isHiddenProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isHidden property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.IsHidden = isHiddenProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - domainFileStore.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - domainFileStore.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - domainFileStore.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - domainFileStore.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the domainFileStore {id} is null", domainFileStore.Iid); + } + else + { + domainFileStore.ThingPreference = thingPreferenceProperty.GetString(); + } } return domainFileStore; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs index e8e10c972..842036389 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,147 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DomainOfExpertiseGroupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var domainOfExpertiseGroup = new CDP4Common.DTO.DomainOfExpertiseGroup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DomainOfExpertiseGroupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - domainOfExpertiseGroup.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var domainOfExpertiseGroup = new CDP4Common.DTO.DomainOfExpertiseGroup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + domainOfExpertiseGroup.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + domainOfExpertiseGroup.Definition.Add(element.GetGuid()); + } } - if (!jObject["domain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("domain"u8, out var domainProperty) && domainProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.Domain.AddRange(jObject["domain"].ToObject>()); + foreach(var element in domainProperty.EnumerateArray()) + { + domainOfExpertiseGroup.Domain.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + domainOfExpertiseGroup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + domainOfExpertiseGroup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertiseGroup.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + domainOfExpertiseGroup.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - domainOfExpertiseGroup.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + } + else + { + domainOfExpertiseGroup.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - domainOfExpertiseGroup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + } + else + { + domainOfExpertiseGroup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - domainOfExpertiseGroup.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + } + else + { + domainOfExpertiseGroup.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - domainOfExpertiseGroup.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + } + else + { + domainOfExpertiseGroup.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - domainOfExpertiseGroup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + } + else + { + domainOfExpertiseGroup.ThingPreference = thingPreferenceProperty.GetString(); + } } return domainOfExpertiseGroup; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs index 4a967c2e1..06cf55214 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,147 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class DomainOfExpertiseResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var domainOfExpertise = new CDP4Common.DTO.DomainOfExpertise(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the DomainOfExpertiseResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - domainOfExpertise.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var domainOfExpertise = new CDP4Common.DTO.DomainOfExpertise(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + domainOfExpertise.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + domainOfExpertise.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + domainOfExpertise.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + domainOfExpertise.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + domainOfExpertise.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - domainOfExpertise.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + domainOfExpertise.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - domainOfExpertise.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + } + else + { + domainOfExpertise.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - domainOfExpertise.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + } + else + { + domainOfExpertise.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - domainOfExpertise.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + } + else + { + domainOfExpertise.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - domainOfExpertise.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + } + else + { + domainOfExpertise.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - domainOfExpertise.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + } + else + { + domainOfExpertise.ThingPreference = thingPreferenceProperty.GetString(); + } } return domainOfExpertise; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DtoFactory.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DtoFactory.cs index 9ff256d51..2ba7c5a7c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DtoFactory.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DtoFactory.cs @@ -2,17 +2,16 @@ // // Copyright (c) 2015-2023 RHEA System S.A. // -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski +// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Jaime Bernar // -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! +// This file is part of CDP4-SDK Community Edition // -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// The CDP4-SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. // -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. @@ -30,11 +29,10 @@ namespace CDP4JsonSerializer { using System; using System.Collections.Generic; - - using CDP4Common.DTO; - - using Newtonsoft.Json.Linq; - + using System.Text.Json; + + using CDP4Common.DTO; + /// /// Utility class that is responsible for instantiating a /// @@ -43,7 +41,7 @@ public static class DtoFactory /// /// The type to Constructor map /// - private static readonly Dictionary> DtoConstructorMap = new Dictionary> + private static readonly Dictionary> DtoConstructorMap = new() { { "ActionItem", ActionItemResolver.FromJsonObject }, { "ActualFiniteState", ActualFiniteStateResolver.FromJsonObject }, @@ -194,20 +192,20 @@ public static class DtoFactory }; /// - /// Instantiates a new from a + /// Instantiates a new from a /// - /// The containing the data + /// The containing the data /// The to instantiate - public static Thing ToDto(this JObject dataObject) + public static Thing ToDto(this JsonElement dataObject) { - var classKind = dataObject["classKind"].ToString(); - Func constructor; - if (!DtoConstructorMap.TryGetValue(classKind, out constructor)) + var classKind = dataObject.GetProperty("classKind").ToString(); + + if(!DtoConstructorMap.TryGetValue(classKind, out var constructor)) { throw new InvalidOperationException($"The dto resolver was not found for {classKind}"); } - return constructor(dataObject); + return constructor.Invoke(dataObject); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs index 27df1b5d1..91c5c81bb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,116 +28,187 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ElementDefinitionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ElementDefinition FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var elementDefinition = new CDP4Common.DTO.ElementDefinition(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ElementDefinitionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - elementDefinition.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var elementDefinition = new CDP4Common.DTO.ElementDefinition(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + elementDefinition.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + elementDefinition.Category.Add(element.GetGuid()); + } } - if (!jObject["containedElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("containedElement"u8, out var containedElementProperty) && containedElementProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.ContainedElement.AddRange(jObject["containedElement"].ToObject>()); + foreach(var element in containedElementProperty.EnumerateArray()) + { + elementDefinition.ContainedElement.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + elementDefinition.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + elementDefinition.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + elementDefinition.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + elementDefinition.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - elementDefinition.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the elementDefinition {id} is null", elementDefinition.Iid); + } + else + { + elementDefinition.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - elementDefinition.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the elementDefinition {id} is null", elementDefinition.Iid); + } + else + { + elementDefinition.Name = nameProperty.GetString(); + } } - if (!jObject["organizationalParticipant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organizationalParticipant"u8, out var organizationalParticipantProperty) && organizationalParticipantProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.OrganizationalParticipant.AddRange(jObject["organizationalParticipant"].ToObject>()); + foreach(var element in organizationalParticipantProperty.EnumerateArray()) + { + elementDefinition.OrganizationalParticipant.Add(element.GetGuid()); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - elementDefinition.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the elementDefinition {id} is null", elementDefinition.Iid); + } + else + { + elementDefinition.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameter"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameter"u8, out var parameterProperty) && parameterProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.Parameter.AddRange(jObject["parameter"].ToObject>()); + foreach(var element in parameterProperty.EnumerateArray()) + { + elementDefinition.Parameter.Add(element.GetGuid()); + } } - if (!jObject["parameterGroup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterGroup"u8, out var parameterGroupProperty) && parameterGroupProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.ParameterGroup.AddRange(jObject["parameterGroup"].ToObject>()); + foreach(var element in parameterGroupProperty.EnumerateArray()) + { + elementDefinition.ParameterGroup.Add(element.GetGuid()); + } } - if (!jObject["referencedElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedElement"u8, out var referencedElementProperty) && referencedElementProperty.ValueKind != JsonValueKind.Null) { - elementDefinition.ReferencedElement.AddRange(jObject["referencedElement"].ToObject>()); + foreach(var element in referencedElementProperty.EnumerateArray()) + { + elementDefinition.ReferencedElement.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - elementDefinition.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the elementDefinition {id} is null", elementDefinition.Iid); + } + else + { + elementDefinition.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - elementDefinition.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the elementDefinition {id} is null", elementDefinition.Iid); + } + else + { + elementDefinition.ThingPreference = thingPreferenceProperty.GetString(); + } } return elementDefinition; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs index fcd002488..8406d81e3 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,187 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ElementUsageResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ElementUsage FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var elementUsage = new CDP4Common.DTO.ElementUsage(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ElementUsageResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - elementUsage.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var elementUsage = new CDP4Common.DTO.ElementUsage(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - elementUsage.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + elementUsage.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - elementUsage.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + elementUsage.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - elementUsage.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + elementUsage.Definition.Add(element.GetGuid()); + } } - if (!jObject["elementDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("elementDefinition"u8, out var elementDefinitionProperty)) { - elementUsage.ElementDefinition = jObject["elementDefinition"].ToObject(); + if(elementDefinitionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale elementDefinition property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.ElementDefinition = elementDefinitionProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - elementUsage.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + elementUsage.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - elementUsage.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + elementUsage.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["excludeOption"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludeOption"u8, out var excludeOptionProperty) && excludeOptionProperty.ValueKind != JsonValueKind.Null) { - elementUsage.ExcludeOption.AddRange(jObject["excludeOption"].ToObject>()); + foreach(var element in excludeOptionProperty.EnumerateArray()) + { + elementUsage.ExcludeOption.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - elementUsage.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + elementUsage.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["interfaceEnd"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("interfaceEnd"u8, out var interfaceEndProperty)) { - elementUsage.InterfaceEnd = jObject["interfaceEnd"].ToObject(); + if(interfaceEndProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale interfaceEnd property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.InterfaceEnd = InterfaceEndKindDeserializer.Deserialize(interfaceEndProperty); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - elementUsage.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - elementUsage.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - elementUsage.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterOverride"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterOverride"u8, out var parameterOverrideProperty) && parameterOverrideProperty.ValueKind != JsonValueKind.Null) { - elementUsage.ParameterOverride.AddRange(jObject["parameterOverride"].ToObject>()); + foreach(var element in parameterOverrideProperty.EnumerateArray()) + { + elementUsage.ParameterOverride.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - elementUsage.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - elementUsage.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the elementUsage {id} is null", elementUsage.Iid); + } + else + { + elementUsage.ThingPreference = thingPreferenceProperty.GetString(); + } } return elementUsage; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs index f9ad1c2fe..de0fbc233 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EmailAddressResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EmailAddress FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EmailAddress FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var emailAddress = new CDP4Common.DTO.EmailAddress(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EmailAddressResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - emailAddress.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var emailAddress = new CDP4Common.DTO.EmailAddress(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - emailAddress.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + emailAddress.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - emailAddress.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + emailAddress.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - emailAddress.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the emailAddress {id} is null", emailAddress.Iid); + } + else + { + emailAddress.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - emailAddress.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the emailAddress {id} is null", emailAddress.Iid); + } + else + { + emailAddress.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - emailAddress.Value = jObject["value"].ToObject(); + if(valueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale value property of the emailAddress {id} is null", emailAddress.Iid); + } + else + { + emailAddress.Value = valueProperty.GetString(); + } } - if (!jObject["vcardType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("vcardType"u8, out var vcardTypeProperty)) { - emailAddress.VcardType = jObject["vcardType"].ToObject(); + if(vcardTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale vcardType property of the emailAddress {id} is null", emailAddress.Iid); + } + else + { + emailAddress.VcardType = VcardEmailAddressKindDeserializer.Deserialize(vcardTypeProperty); + } } return emailAddress; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs index 46728856a..3cd779c8f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EngineeringModelDataDiscussionItemResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var engineeringModelDataDiscussionItem = new CDP4Common.DTO.EngineeringModelDataDiscussionItem(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EngineeringModelDataDiscussionItemResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - engineeringModelDataDiscussionItem.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var engineeringModelDataDiscussionItem = new CDP4Common.DTO.EngineeringModelDataDiscussionItem(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - engineeringModelDataDiscussionItem.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.Author = authorProperty.GetGuid(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - engineeringModelDataDiscussionItem.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - engineeringModelDataDiscussionItem.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataDiscussionItem.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + engineeringModelDataDiscussionItem.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataDiscussionItem.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + engineeringModelDataDiscussionItem.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - engineeringModelDataDiscussionItem.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - engineeringModelDataDiscussionItem.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["replyTo"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("replyTo"u8, out var replyToProperty)) { - engineeringModelDataDiscussionItem.ReplyTo = jObject["replyTo"].ToObject(); + if(replyToProperty.ValueKind == JsonValueKind.Null) + { + engineeringModelDataDiscussionItem.ReplyTo = null; + } + else + { + engineeringModelDataDiscussionItem.ReplyTo = replyToProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - engineeringModelDataDiscussionItem.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + } + else + { + engineeringModelDataDiscussionItem.ThingPreference = thingPreferenceProperty.GetString(); + } } return engineeringModelDataDiscussionItem; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs index 409a21d17..d49355db9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,155 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EngineeringModelDataNoteResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var engineeringModelDataNote = new CDP4Common.DTO.EngineeringModelDataNote(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EngineeringModelDataNoteResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - engineeringModelDataNote.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var engineeringModelDataNote = new CDP4Common.DTO.EngineeringModelDataNote(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - engineeringModelDataNote.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.Author = authorProperty.GetGuid(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - engineeringModelDataNote.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - engineeringModelDataNote.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataNote.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + engineeringModelDataNote.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataNote.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + engineeringModelDataNote.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataNote.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + engineeringModelDataNote.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - engineeringModelDataNote.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - engineeringModelDataNote.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - engineeringModelDataNote.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + engineeringModelDataNote.PrimaryAnnotatedThing = null; + } + else + { + engineeringModelDataNote.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - engineeringModelDataNote.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + engineeringModelDataNote.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - engineeringModelDataNote.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + } + else + { + engineeringModelDataNote.ThingPreference = thingPreferenceProperty.GetString(); + } } return engineeringModelDataNote; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs index 10f480a5e..f4f0ac12d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,148 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EngineeringModelResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EngineeringModel FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EngineeringModel FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var engineeringModel = new CDP4Common.DTO.EngineeringModel(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EngineeringModelResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - engineeringModel.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["book"].IsNullOrEmpty()) + var engineeringModel = new CDP4Common.DTO.EngineeringModel(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("book"u8, out var bookProperty)) { - engineeringModel.Book.AddRange(jObject["book"].ToOrderedItemCollection()); + engineeringModel.Book.AddRange(bookProperty.ToOrderedItemCollection()); } - if (!jObject["commonFileStore"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("commonFileStore"u8, out var commonFileStoreProperty) && commonFileStoreProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.CommonFileStore.AddRange(jObject["commonFileStore"].ToObject>()); + foreach(var element in commonFileStoreProperty.EnumerateArray()) + { + engineeringModel.CommonFileStore.Add(element.GetGuid()); + } } - if (!jObject["engineeringModelSetup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("engineeringModelSetup"u8, out var engineeringModelSetupProperty)) { - engineeringModel.EngineeringModelSetup = jObject["engineeringModelSetup"].ToObject(); + if(engineeringModelSetupProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale engineeringModelSetup property of the engineeringModel {id} is null", engineeringModel.Iid); + } + else + { + engineeringModel.EngineeringModelSetup = engineeringModelSetupProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + engineeringModel.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + engineeringModel.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["genericNote"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("genericNote"u8, out var genericNoteProperty) && genericNoteProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.GenericNote.AddRange(jObject["genericNote"].ToObject>()); + foreach(var element in genericNoteProperty.EnumerateArray()) + { + engineeringModel.GenericNote.Add(element.GetGuid()); + } } - if (!jObject["iteration"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("iteration"u8, out var iterationProperty) && iterationProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.Iteration.AddRange(jObject["iteration"].ToObject>()); + foreach(var element in iterationProperty.EnumerateArray()) + { + engineeringModel.Iteration.Add(element.GetGuid()); + } } - if (!jObject["lastModifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("lastModifiedOn"u8, out var lastModifiedOnProperty)) { - engineeringModel.LastModifiedOn = jObject["lastModifiedOn"].ToObject(); + if(lastModifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale lastModifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); + } + else + { + engineeringModel.LastModifiedOn = lastModifiedOnProperty.GetDateTime(); + } } - if (!jObject["logEntry"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("logEntry"u8, out var logEntryProperty) && logEntryProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.LogEntry.AddRange(jObject["logEntry"].ToObject>()); + foreach(var element in logEntryProperty.EnumerateArray()) + { + engineeringModel.LogEntry.Add(element.GetGuid()); + } } - if (!jObject["modellingAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modellingAnnotation"u8, out var modellingAnnotationProperty) && modellingAnnotationProperty.ValueKind != JsonValueKind.Null) { - engineeringModel.ModellingAnnotation.AddRange(jObject["modellingAnnotation"].ToObject>()); + foreach(var element in modellingAnnotationProperty.EnumerateArray()) + { + engineeringModel.ModellingAnnotation.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - engineeringModel.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); + } + else + { + engineeringModel.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - engineeringModel.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the engineeringModel {id} is null", engineeringModel.Iid); + } + else + { + engineeringModel.ThingPreference = thingPreferenceProperty.GetString(); + } } return engineeringModel; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs index 64efc44ba..a0a05f287 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,131 +28,227 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EngineeringModelSetupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var engineeringModelSetup = new CDP4Common.DTO.EngineeringModelSetup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EngineeringModelSetupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["activeDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - engineeringModelSetup.ActiveDomain.AddRange(jObject["activeDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actor"].IsNullOrEmpty()) + var engineeringModelSetup = new CDP4Common.DTO.EngineeringModelSetup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("activeDomain"u8, out var activeDomainProperty) && activeDomainProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.Actor = jObject["actor"].ToObject(); + foreach(var element in activeDomainProperty.EnumerateArray()) + { + engineeringModelSetup.ActiveDomain.Add(element.GetGuid()); + } } - if (!jObject["alias"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + engineeringModelSetup.Alias.Add(element.GetGuid()); + } } - if (!jObject["defaultOrganizationalParticipant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultOrganizationalParticipant"u8, out var defaultOrganizationalParticipantProperty)) { - engineeringModelSetup.DefaultOrganizationalParticipant = jObject["defaultOrganizationalParticipant"].ToObject(); + if(defaultOrganizationalParticipantProperty.ValueKind == JsonValueKind.Null) + { + engineeringModelSetup.DefaultOrganizationalParticipant = null; + } + else + { + engineeringModelSetup.DefaultOrganizationalParticipant = defaultOrganizationalParticipantProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + engineeringModelSetup.Definition.Add(element.GetGuid()); + } } - if (!jObject["engineeringModelIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("engineeringModelIid"u8, out var engineeringModelIidProperty)) { - engineeringModelSetup.EngineeringModelIid = jObject["engineeringModelIid"].ToObject(); + if(engineeringModelIidProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale engineeringModelIid property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.EngineeringModelIid = engineeringModelIidProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + engineeringModelSetup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + engineeringModelSetup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + engineeringModelSetup.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["iterationSetup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("iterationSetup"u8, out var iterationSetupProperty) && iterationSetupProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.IterationSetup.AddRange(jObject["iterationSetup"].ToObject>()); + foreach(var element in iterationSetupProperty.EnumerateArray()) + { + engineeringModelSetup.IterationSetup.Add(element.GetGuid()); + } } - if (!jObject["kind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("kind"u8, out var kindProperty)) { - engineeringModelSetup.Kind = jObject["kind"].ToObject(); + if(kindProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale kind property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.Kind = EngineeringModelKindDeserializer.Deserialize(kindProperty); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - engineeringModelSetup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - engineeringModelSetup.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.Name = nameProperty.GetString(); + } } - if (!jObject["organizationalParticipant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organizationalParticipant"u8, out var organizationalParticipantProperty) && organizationalParticipantProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.OrganizationalParticipant.AddRange(jObject["organizationalParticipant"].ToObject>()); + foreach(var element in organizationalParticipantProperty.EnumerateArray()) + { + engineeringModelSetup.OrganizationalParticipant.Add(element.GetGuid()); + } } - if (!jObject["participant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("participant"u8, out var participantProperty) && participantProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.Participant.AddRange(jObject["participant"].ToObject>()); + foreach(var element in participantProperty.EnumerateArray()) + { + engineeringModelSetup.Participant.Add(element.GetGuid()); + } } - if (!jObject["requiredRdl"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requiredRdl"u8, out var requiredRdlProperty) && requiredRdlProperty.ValueKind != JsonValueKind.Null) { - engineeringModelSetup.RequiredRdl.AddRange(jObject["requiredRdl"].ToObject>()); + foreach(var element in requiredRdlProperty.EnumerateArray()) + { + engineeringModelSetup.RequiredRdl.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - engineeringModelSetup.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceEngineeringModelSetupIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceEngineeringModelSetupIid"u8, out var sourceEngineeringModelSetupIidProperty)) { - engineeringModelSetup.SourceEngineeringModelSetupIid = jObject["sourceEngineeringModelSetupIid"].ToObject(); + if(sourceEngineeringModelSetupIidProperty.ValueKind == JsonValueKind.Null) + { + engineeringModelSetup.SourceEngineeringModelSetupIid = null; + } + else + { + engineeringModelSetup.SourceEngineeringModelSetupIid = sourceEngineeringModelSetupIidProperty.GetGuid(); + } } - if (!jObject["studyPhase"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("studyPhase"u8, out var studyPhaseProperty)) { - engineeringModelSetup.StudyPhase = jObject["studyPhase"].ToObject(); + if(studyPhaseProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale studyPhase property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.StudyPhase = StudyPhaseKindDeserializer.Deserialize(studyPhaseProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - engineeringModelSetup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + } + else + { + engineeringModelSetup.ThingPreference = thingPreferenceProperty.GetString(); + } } return engineeringModelSetup; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs index 54ddc8d5b..6059bd7aa 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,176 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EnumerationParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var enumerationParameterType = new CDP4Common.DTO.EnumerationParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EnumerationParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - enumerationParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var enumerationParameterType = new CDP4Common.DTO.EnumerationParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + enumerationParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["allowMultiSelect"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("allowMultiSelect"u8, out var allowMultiSelectProperty)) { - enumerationParameterType.AllowMultiSelect = jObject["allowMultiSelect"].ToObject(); + if(allowMultiSelectProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale allowMultiSelect property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.AllowMultiSelect = allowMultiSelectProperty.GetBoolean(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + enumerationParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + enumerationParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + enumerationParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + enumerationParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - enumerationParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + enumerationParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - enumerationParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - enumerationParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - enumerationParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - enumerationParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - enumerationParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - enumerationParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + } + else + { + enumerationParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty)) { - enumerationParameterType.ValueDefinition.AddRange(jObject["valueDefinition"].ToOrderedItemCollection()); + enumerationParameterType.ValueDefinition.AddRange(valueDefinitionProperty.ToOrderedItemCollection()); } return enumerationParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs index 5b475059b..b0db8660e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class EnumerationValueDefinitionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var enumerationValueDefinition = new CDP4Common.DTO.EnumerationValueDefinition(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the EnumerationValueDefinitionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - enumerationValueDefinition.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var enumerationValueDefinition = new CDP4Common.DTO.EnumerationValueDefinition(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - enumerationValueDefinition.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + enumerationValueDefinition.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - enumerationValueDefinition.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + enumerationValueDefinition.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - enumerationValueDefinition.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + enumerationValueDefinition.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - enumerationValueDefinition.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + enumerationValueDefinition.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - enumerationValueDefinition.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + enumerationValueDefinition.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - enumerationValueDefinition.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + } + else + { + enumerationValueDefinition.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - enumerationValueDefinition.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + } + else + { + enumerationValueDefinition.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - enumerationValueDefinition.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + } + else + { + enumerationValueDefinition.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - enumerationValueDefinition.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + } + else + { + enumerationValueDefinition.ThingPreference = thingPreferenceProperty.GetString(); + } } return enumerationValueDefinition; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs index 9708214d8..62d37fbb2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,61 +28,87 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ExclusiveOrExpressionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ExclusiveOrExpression FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ExclusiveOrExpression FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var exclusiveOrExpression = new CDP4Common.DTO.ExclusiveOrExpression(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ExclusiveOrExpressionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - exclusiveOrExpression.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var exclusiveOrExpression = new CDP4Common.DTO.ExclusiveOrExpression(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - exclusiveOrExpression.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + exclusiveOrExpression.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - exclusiveOrExpression.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + exclusiveOrExpression.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - exclusiveOrExpression.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); + } + else + { + exclusiveOrExpression.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["term"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("term"u8, out var termProperty) && termProperty.ValueKind != JsonValueKind.Null) { - exclusiveOrExpression.Term.AddRange(jObject["term"].ToObject>()); + foreach(var element in termProperty.EnumerateArray()) + { + exclusiveOrExpression.Term.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - exclusiveOrExpression.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); + } + else + { + exclusiveOrExpression.ThingPreference = thingPreferenceProperty.GetString(); + } } return exclusiveOrExpression; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs index f168262a2..242f14aac 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ExternalIdentifierMapResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var externalIdentifierMap = new CDP4Common.DTO.ExternalIdentifierMap(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ExternalIdentifierMapResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - externalIdentifierMap.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["correspondence"].IsNullOrEmpty()) + var externalIdentifierMap = new CDP4Common.DTO.ExternalIdentifierMap(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("correspondence"u8, out var correspondenceProperty) && correspondenceProperty.ValueKind != JsonValueKind.Null) { - externalIdentifierMap.Correspondence.AddRange(jObject["correspondence"].ToObject>()); + foreach(var element in correspondenceProperty.EnumerateArray()) + { + externalIdentifierMap.Correspondence.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - externalIdentifierMap.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + externalIdentifierMap.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - externalIdentifierMap.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + externalIdentifierMap.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["externalFormat"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalFormat"u8, out var externalFormatProperty)) { - externalIdentifierMap.ExternalFormat = jObject["externalFormat"].ToObject(); + if(externalFormatProperty.ValueKind == JsonValueKind.Null) + { + externalIdentifierMap.ExternalFormat = null; + } + else + { + externalIdentifierMap.ExternalFormat = externalFormatProperty.GetGuid(); + } } - if (!jObject["externalModelName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalModelName"u8, out var externalModelNameProperty)) { - externalIdentifierMap.ExternalModelName = jObject["externalModelName"].ToObject(); + if(externalModelNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale externalModelName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.ExternalModelName = externalModelNameProperty.GetString(); + } } - if (!jObject["externalToolName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalToolName"u8, out var externalToolNameProperty)) { - externalIdentifierMap.ExternalToolName = jObject["externalToolName"].ToObject(); + if(externalToolNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale externalToolName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.ExternalToolName = externalToolNameProperty.GetString(); + } } - if (!jObject["externalToolVersion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalToolVersion"u8, out var externalToolVersionProperty)) { - externalIdentifierMap.ExternalToolVersion = jObject["externalToolVersion"].ToObject(); + if(externalToolVersionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale externalToolVersion property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.ExternalToolVersion = externalToolVersionProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - externalIdentifierMap.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - externalIdentifierMap.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - externalIdentifierMap.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - externalIdentifierMap.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + } + else + { + externalIdentifierMap.ThingPreference = thingPreferenceProperty.GetString(); + } } return externalIdentifierMap; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs index f3256bef9..d7f52a5db 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,119 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class FileResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.File FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.File FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var file = new CDP4Common.DTO.File(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the FileResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - file.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var file = new CDP4Common.DTO.File(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - file.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + file.Category.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - file.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + file.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - file.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + file.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fileRevision"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fileRevision"u8, out var fileRevisionProperty) && fileRevisionProperty.ValueKind != JsonValueKind.Null) { - file.FileRevision.AddRange(jObject["fileRevision"].ToObject>()); + foreach(var element in fileRevisionProperty.EnumerateArray()) + { + file.FileRevision.Add(element.GetGuid()); + } } - if (!jObject["lockedBy"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("lockedBy"u8, out var lockedByProperty)) { - file.LockedBy = jObject["lockedBy"].ToObject(); + if(lockedByProperty.ValueKind == JsonValueKind.Null) + { + file.LockedBy = null; + } + else + { + file.LockedBy = lockedByProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - file.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the file {id} is null", file.Iid); + } + else + { + file.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - file.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the file {id} is null", file.Iid); + } + else + { + file.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - file.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the file {id} is null", file.Iid); + } + else + { + file.ThingPreference = thingPreferenceProperty.GetString(); + } } return file; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs index 972ac1e0a..e7dc7b9bc 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,144 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class FileRevisionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.FileRevision FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var fileRevision = new CDP4Common.DTO.FileRevision(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the FileRevisionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - fileRevision.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["containingFolder"].IsNullOrEmpty()) + var fileRevision = new CDP4Common.DTO.FileRevision(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("containingFolder"u8, out var containingFolderProperty)) { - fileRevision.ContainingFolder = jObject["containingFolder"].ToObject(); + if(containingFolderProperty.ValueKind == JsonValueKind.Null) + { + fileRevision.ContainingFolder = null; + } + else + { + fileRevision.ContainingFolder = containingFolderProperty.GetGuid(); + } } - if (!jObject["contentHash"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("contentHash"u8, out var contentHashProperty)) { - fileRevision.ContentHash = jObject["contentHash"].ToObject(); + if(contentHashProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale contentHash property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.ContentHash = contentHashProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - fileRevision.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["creator"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("creator"u8, out var creatorProperty)) { - fileRevision.Creator = jObject["creator"].ToObject(); + if(creatorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale creator property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.Creator = creatorProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - fileRevision.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + fileRevision.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - fileRevision.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + fileRevision.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fileType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fileType"u8, out var fileTypeProperty)) { - fileRevision.FileType.AddRange(jObject["fileType"].ToOrderedItemCollection()); + fileRevision.FileType.AddRange(fileTypeProperty.ToOrderedItemCollection()); } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - fileRevision.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - fileRevision.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - fileRevision.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the fileRevision {id} is null", fileRevision.Iid); + } + else + { + fileRevision.ThingPreference = thingPreferenceProperty.GetString(); + } } return fileRevision; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs index 323d805cf..15a415fa9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class FileTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.FileType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var fileType = new CDP4Common.DTO.FileType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the FileTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - fileType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var fileType = new CDP4Common.DTO.FileType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - fileType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + fileType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - fileType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + fileType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - fileType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + fileType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - fileType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + fileType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - fileType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + fileType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["extension"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("extension"u8, out var extensionProperty)) { - fileType.Extension = jObject["extension"].ToObject(); + if(extensionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale extension property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.Extension = extensionProperty.GetString(); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - fileType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + fileType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - fileType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - fileType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - fileType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - fileType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - fileType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the fileType {id} is null", fileType.Iid); + } + else + { + fileType.ThingPreference = thingPreferenceProperty.GetString(); + } } return fileType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs index 4fbc9d09a..61957f20b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class FolderResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Folder FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var folder = new CDP4Common.DTO.Folder(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the FolderResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - folder.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["containingFolder"].IsNullOrEmpty()) + var folder = new CDP4Common.DTO.Folder(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("containingFolder"u8, out var containingFolderProperty)) { - folder.ContainingFolder = jObject["containingFolder"].ToObject(); + if(containingFolderProperty.ValueKind == JsonValueKind.Null) + { + folder.ContainingFolder = null; + } + else + { + folder.ContainingFolder = containingFolderProperty.GetGuid(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - folder.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the folder {id} is null", folder.Iid); + } + else + { + folder.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["creator"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("creator"u8, out var creatorProperty)) { - folder.Creator = jObject["creator"].ToObject(); + if(creatorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale creator property of the folder {id} is null", folder.Iid); + } + else + { + folder.Creator = creatorProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - folder.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + folder.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - folder.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + folder.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - folder.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the folder {id} is null", folder.Iid); + } + else + { + folder.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - folder.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the folder {id} is null", folder.Iid); + } + else + { + folder.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - folder.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the folder {id} is null", folder.Iid); + } + else + { + folder.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - folder.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the folder {id} is null", folder.Iid); + } + else + { + folder.ThingPreference = thingPreferenceProperty.GetString(); + } } return folder; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs index 2032ed59d..0b62a5f65 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,155 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class GlossaryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Glossary FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var glossary = new CDP4Common.DTO.Glossary(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the GlossaryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - glossary.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var glossary = new CDP4Common.DTO.Glossary(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - glossary.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + glossary.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - glossary.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + glossary.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - glossary.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + glossary.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - glossary.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + glossary.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - glossary.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + glossary.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - glossary.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + glossary.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - glossary.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the glossary {id} is null", glossary.Iid); + } + else + { + glossary.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - glossary.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the glossary {id} is null", glossary.Iid); + } + else + { + glossary.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - glossary.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the glossary {id} is null", glossary.Iid); + } + else + { + glossary.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - glossary.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the glossary {id} is null", glossary.Iid); + } + else + { + glossary.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["term"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("term"u8, out var termProperty) && termProperty.ValueKind != JsonValueKind.Null) { - glossary.Term.AddRange(jObject["term"].ToObject>()); + foreach(var element in termProperty.EnumerateArray()) + { + glossary.Term.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - glossary.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the glossary {id} is null", glossary.Iid); + } + else + { + glossary.ThingPreference = thingPreferenceProperty.GetString(); + } } return glossary; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs index b1a0e8b94..add132c03 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,135 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class GoalResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Goal FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Goal FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var goal = new CDP4Common.DTO.Goal(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the GoalResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - goal.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var goal = new CDP4Common.DTO.Goal(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - goal.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + goal.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - goal.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + goal.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - goal.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + goal.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - goal.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + goal.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - goal.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + goal.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - goal.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + goal.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - goal.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the goal {id} is null", goal.Iid); + } + else + { + goal.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - goal.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the goal {id} is null", goal.Iid); + } + else + { + goal.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - goal.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the goal {id} is null", goal.Iid); + } + else + { + goal.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - goal.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the goal {id} is null", goal.Iid); + } + else + { + goal.ThingPreference = thingPreferenceProperty.GetString(); + } } return goal; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs index 05bb163bf..2a47f983c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class HyperLinkResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.HyperLink FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var hyperLink = new CDP4Common.DTO.HyperLink(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the HyperLinkResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - hyperLink.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["content"].IsNullOrEmpty()) + var hyperLink = new CDP4Common.DTO.HyperLink(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - hyperLink.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the hyperLink {id} is null", hyperLink.Iid); + } + else + { + hyperLink.Content = contentProperty.GetString(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - hyperLink.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + hyperLink.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - hyperLink.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + hyperLink.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - hyperLink.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the hyperLink {id} is null", hyperLink.Iid); + } + else + { + hyperLink.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - hyperLink.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the hyperLink {id} is null", hyperLink.Iid); + } + else + { + hyperLink.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - hyperLink.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the hyperLink {id} is null", hyperLink.Iid); + } + else + { + hyperLink.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["uri"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("uri"u8, out var uriProperty)) { - hyperLink.Uri = jObject["uri"].ToObject(); + if(uriProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale uri property of the hyperLink {id} is null", hyperLink.Iid); + } + else + { + hyperLink.Uri = uriProperty.GetString(); + } } return hyperLink; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs index 3cffd872f..dc573c684 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class IdCorrespondenceResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var idCorrespondence = new CDP4Common.DTO.IdCorrespondence(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the IdCorrespondenceResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - idCorrespondence.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var idCorrespondence = new CDP4Common.DTO.IdCorrespondence(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - idCorrespondence.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + idCorrespondence.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - idCorrespondence.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + idCorrespondence.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["externalId"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalId"u8, out var externalIdProperty)) { - idCorrespondence.ExternalId = jObject["externalId"].ToObject(); + if(externalIdProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale externalId property of the idCorrespondence {id} is null", idCorrespondence.Iid); + } + else + { + idCorrespondence.ExternalId = externalIdProperty.GetString(); + } } - if (!jObject["internalThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("internalThing"u8, out var internalThingProperty)) { - idCorrespondence.InternalThing = jObject["internalThing"].ToObject(); + if(internalThingProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale internalThing property of the idCorrespondence {id} is null", idCorrespondence.Iid); + } + else + { + idCorrespondence.InternalThing = internalThingProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - idCorrespondence.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the idCorrespondence {id} is null", idCorrespondence.Iid); + } + else + { + idCorrespondence.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - idCorrespondence.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the idCorrespondence {id} is null", idCorrespondence.Iid); + } + else + { + idCorrespondence.ThingPreference = thingPreferenceProperty.GetString(); + } } return idCorrespondence; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs index 21471938e..2d8f77bb6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class IndependentParameterTypeAssignmentResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.IndependentParameterTypeAssignment FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.IndependentParameterTypeAssignment FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var independentParameterTypeAssignment = new CDP4Common.DTO.IndependentParameterTypeAssignment(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the IndependentParameterTypeAssignmentResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - independentParameterTypeAssignment.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var independentParameterTypeAssignment = new CDP4Common.DTO.IndependentParameterTypeAssignment(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - independentParameterTypeAssignment.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + independentParameterTypeAssignment.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - independentParameterTypeAssignment.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + independentParameterTypeAssignment.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["measurementScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("measurementScale"u8, out var measurementScaleProperty)) { - independentParameterTypeAssignment.MeasurementScale = jObject["measurementScale"].ToObject(); + if(measurementScaleProperty.ValueKind == JsonValueKind.Null) + { + independentParameterTypeAssignment.MeasurementScale = null; + } + else + { + independentParameterTypeAssignment.MeasurementScale = measurementScaleProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - independentParameterTypeAssignment.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + } + else + { + independentParameterTypeAssignment.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - independentParameterTypeAssignment.ParameterType = jObject["parameterType"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + } + else + { + independentParameterTypeAssignment.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - independentParameterTypeAssignment.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + } + else + { + independentParameterTypeAssignment.ThingPreference = thingPreferenceProperty.GetString(); + } } return independentParameterTypeAssignment; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs index 7b96dc691..ca2a5d4c8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,136 +28,251 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class IntervalScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.IntervalScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var intervalScale = new CDP4Common.DTO.IntervalScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the IntervalScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - intervalScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var intervalScale = new CDP4Common.DTO.IntervalScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - intervalScale.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + intervalScale.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - intervalScale.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + intervalScale.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - intervalScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + intervalScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - intervalScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + intervalScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - intervalScale.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + intervalScale.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - intervalScale.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isMaximumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMaximumInclusive"u8, out var isMaximumInclusiveProperty)) { - intervalScale.IsMaximumInclusive = jObject["isMaximumInclusive"].ToObject(); + if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMaximumInclusive property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.IsMaximumInclusive = isMaximumInclusiveProperty.GetBoolean(); + } } - if (!jObject["isMinimumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMinimumInclusive"u8, out var isMinimumInclusiveProperty)) { - intervalScale.IsMinimumInclusive = jObject["isMinimumInclusive"].ToObject(); + if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMinimumInclusive property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.IsMinimumInclusive = isMinimumInclusiveProperty.GetBoolean(); + } } - if (!jObject["mappingToReferenceScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("mappingToReferenceScale"u8, out var mappingToReferenceScaleProperty) && mappingToReferenceScaleProperty.ValueKind != JsonValueKind.Null) { - intervalScale.MappingToReferenceScale.AddRange(jObject["mappingToReferenceScale"].ToObject>()); + foreach(var element in mappingToReferenceScaleProperty.EnumerateArray()) + { + intervalScale.MappingToReferenceScale.Add(element.GetGuid()); + } } - if (!jObject["maximumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maximumPermissibleValue"u8, out var maximumPermissibleValueProperty)) { - intervalScale.MaximumPermissibleValue = jObject["maximumPermissibleValue"].ToObject(); + if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maximumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.MaximumPermissibleValue = maximumPermissibleValueProperty.GetString(); + } } - if (!jObject["minimumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minimumPermissibleValue"u8, out var minimumPermissibleValueProperty)) { - intervalScale.MinimumPermissibleValue = jObject["minimumPermissibleValue"].ToObject(); + if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minimumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.MinimumPermissibleValue = minimumPermissibleValueProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - intervalScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - intervalScale.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.Name = nameProperty.GetString(); + } } - if (!jObject["negativeValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("negativeValueConnotation"u8, out var negativeValueConnotationProperty)) { - intervalScale.NegativeValueConnotation = jObject["negativeValueConnotation"].ToObject(); + if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale negativeValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.NegativeValueConnotation = negativeValueConnotationProperty.GetString(); + } } - if (!jObject["numberSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("numberSet"u8, out var numberSetProperty)) { - intervalScale.NumberSet = jObject["numberSet"].ToObject(); + if(numberSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale numberSet property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.NumberSet = NumberSetKindDeserializer.Deserialize(numberSetProperty); + } } - if (!jObject["positiveValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("positiveValueConnotation"u8, out var positiveValueConnotationProperty)) { - intervalScale.PositiveValueConnotation = jObject["positiveValueConnotation"].ToObject(); + if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale positiveValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.PositiveValueConnotation = positiveValueConnotationProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - intervalScale.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - intervalScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - intervalScale.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the intervalScale {id} is null", intervalScale.Iid); + } + else + { + intervalScale.Unit = unitProperty.GetGuid(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty) && valueDefinitionProperty.ValueKind != JsonValueKind.Null) { - intervalScale.ValueDefinition.AddRange(jObject["valueDefinition"].ToObject>()); + foreach(var element in valueDefinitionProperty.EnumerateArray()) + { + intervalScale.ValueDefinition.Add(element.GetGuid()); + } } return intervalScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs index 72117f3b8..ffc947b3f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,161 +28,260 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class IterationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Iteration FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Iteration FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var iteration = new CDP4Common.DTO.Iteration(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the IterationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - iteration.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actualFiniteStateList"].IsNullOrEmpty()) + var iteration = new CDP4Common.DTO.Iteration(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("actualFiniteStateList"u8, out var actualFiniteStateListProperty) && actualFiniteStateListProperty.ValueKind != JsonValueKind.Null) { - iteration.ActualFiniteStateList.AddRange(jObject["actualFiniteStateList"].ToObject>()); + foreach(var element in actualFiniteStateListProperty.EnumerateArray()) + { + iteration.ActualFiniteStateList.Add(element.GetGuid()); + } } - if (!jObject["defaultOption"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultOption"u8, out var defaultOptionProperty)) { - iteration.DefaultOption = jObject["defaultOption"].ToObject(); + if(defaultOptionProperty.ValueKind == JsonValueKind.Null) + { + iteration.DefaultOption = null; + } + else + { + iteration.DefaultOption = defaultOptionProperty.GetGuid(); + } } - if (!jObject["diagramCanvas"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("diagramCanvas"u8, out var diagramCanvasProperty) && diagramCanvasProperty.ValueKind != JsonValueKind.Null) { - iteration.DiagramCanvas.AddRange(jObject["diagramCanvas"].ToObject>()); + foreach(var element in diagramCanvasProperty.EnumerateArray()) + { + iteration.DiagramCanvas.Add(element.GetGuid()); + } } - if (!jObject["domainFileStore"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("domainFileStore"u8, out var domainFileStoreProperty) && domainFileStoreProperty.ValueKind != JsonValueKind.Null) { - iteration.DomainFileStore.AddRange(jObject["domainFileStore"].ToObject>()); + foreach(var element in domainFileStoreProperty.EnumerateArray()) + { + iteration.DomainFileStore.Add(element.GetGuid()); + } } - if (!jObject["element"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("element"u8, out var elementProperty) && elementProperty.ValueKind != JsonValueKind.Null) { - iteration.Element.AddRange(jObject["element"].ToObject>()); + foreach(var element in elementProperty.EnumerateArray()) + { + iteration.Element.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - iteration.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + iteration.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - iteration.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + iteration.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["externalIdentifierMap"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("externalIdentifierMap"u8, out var externalIdentifierMapProperty) && externalIdentifierMapProperty.ValueKind != JsonValueKind.Null) { - iteration.ExternalIdentifierMap.AddRange(jObject["externalIdentifierMap"].ToObject>()); + foreach(var element in externalIdentifierMapProperty.EnumerateArray()) + { + iteration.ExternalIdentifierMap.Add(element.GetGuid()); + } } - if (!jObject["goal"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("goal"u8, out var goalProperty) && goalProperty.ValueKind != JsonValueKind.Null) { - iteration.Goal.AddRange(jObject["goal"].ToObject>()); + foreach(var element in goalProperty.EnumerateArray()) + { + iteration.Goal.Add(element.GetGuid()); + } } - if (!jObject["iterationSetup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("iterationSetup"u8, out var iterationSetupProperty)) { - iteration.IterationSetup = jObject["iterationSetup"].ToObject(); + if(iterationSetupProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale iterationSetup property of the iteration {id} is null", iteration.Iid); + } + else + { + iteration.IterationSetup = iterationSetupProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - iteration.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the iteration {id} is null", iteration.Iid); + } + else + { + iteration.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["option"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("option"u8, out var optionProperty)) { - iteration.Option.AddRange(jObject["option"].ToOrderedItemCollection()); + iteration.Option.AddRange(optionProperty.ToOrderedItemCollection()); } - if (!jObject["possibleFiniteStateList"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleFiniteStateList"u8, out var possibleFiniteStateListProperty) && possibleFiniteStateListProperty.ValueKind != JsonValueKind.Null) { - iteration.PossibleFiniteStateList.AddRange(jObject["possibleFiniteStateList"].ToObject>()); + foreach(var element in possibleFiniteStateListProperty.EnumerateArray()) + { + iteration.PossibleFiniteStateList.Add(element.GetGuid()); + } } - if (!jObject["publication"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("publication"u8, out var publicationProperty) && publicationProperty.ValueKind != JsonValueKind.Null) { - iteration.Publication.AddRange(jObject["publication"].ToObject>()); + foreach(var element in publicationProperty.EnumerateArray()) + { + iteration.Publication.Add(element.GetGuid()); + } } - if (!jObject["relationship"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relationship"u8, out var relationshipProperty) && relationshipProperty.ValueKind != JsonValueKind.Null) { - iteration.Relationship.AddRange(jObject["relationship"].ToObject>()); + foreach(var element in relationshipProperty.EnumerateArray()) + { + iteration.Relationship.Add(element.GetGuid()); + } } - if (!jObject["requirementsSpecification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requirementsSpecification"u8, out var requirementsSpecificationProperty) && requirementsSpecificationProperty.ValueKind != JsonValueKind.Null) { - iteration.RequirementsSpecification.AddRange(jObject["requirementsSpecification"].ToObject>()); + foreach(var element in requirementsSpecificationProperty.EnumerateArray()) + { + iteration.RequirementsSpecification.Add(element.GetGuid()); + } } - if (!jObject["ruleVerificationList"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("ruleVerificationList"u8, out var ruleVerificationListProperty) && ruleVerificationListProperty.ValueKind != JsonValueKind.Null) { - iteration.RuleVerificationList.AddRange(jObject["ruleVerificationList"].ToObject>()); + foreach(var element in ruleVerificationListProperty.EnumerateArray()) + { + iteration.RuleVerificationList.Add(element.GetGuid()); + } } - if (!jObject["sharedDiagramStyle"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sharedDiagramStyle"u8, out var sharedDiagramStyleProperty) && sharedDiagramStyleProperty.ValueKind != JsonValueKind.Null) { - iteration.SharedDiagramStyle.AddRange(jObject["sharedDiagramStyle"].ToObject>()); + foreach(var element in sharedDiagramStyleProperty.EnumerateArray()) + { + iteration.SharedDiagramStyle.Add(element.GetGuid()); + } } - if (!jObject["sourceIterationIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceIterationIid"u8, out var sourceIterationIidProperty)) { - iteration.SourceIterationIid = jObject["sourceIterationIid"].ToObject(); + if(sourceIterationIidProperty.ValueKind == JsonValueKind.Null) + { + iteration.SourceIterationIid = null; + } + else + { + iteration.SourceIterationIid = sourceIterationIidProperty.GetGuid(); + } } - if (!jObject["stakeholder"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholder"u8, out var stakeholderProperty) && stakeholderProperty.ValueKind != JsonValueKind.Null) { - iteration.Stakeholder.AddRange(jObject["stakeholder"].ToObject>()); + foreach(var element in stakeholderProperty.EnumerateArray()) + { + iteration.Stakeholder.Add(element.GetGuid()); + } } - if (!jObject["stakeholderValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholderValue"u8, out var stakeholderValueProperty) && stakeholderValueProperty.ValueKind != JsonValueKind.Null) { - iteration.StakeholderValue.AddRange(jObject["stakeholderValue"].ToObject>()); + foreach(var element in stakeholderValueProperty.EnumerateArray()) + { + iteration.StakeholderValue.Add(element.GetGuid()); + } } - if (!jObject["stakeholderValueMap"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholderValueMap"u8, out var stakeholderValueMapProperty) && stakeholderValueMapProperty.ValueKind != JsonValueKind.Null) { - iteration.StakeholderValueMap.AddRange(jObject["stakeholderValueMap"].ToObject>()); + foreach(var element in stakeholderValueMapProperty.EnumerateArray()) + { + iteration.StakeholderValueMap.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - iteration.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the iteration {id} is null", iteration.Iid); + } + else + { + iteration.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["topElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("topElement"u8, out var topElementProperty)) { - iteration.TopElement = jObject["topElement"].ToObject(); + if(topElementProperty.ValueKind == JsonValueKind.Null) + { + iteration.TopElement = null; + } + else + { + iteration.TopElement = topElementProperty.GetGuid(); + } } - if (!jObject["valueGroup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueGroup"u8, out var valueGroupProperty) && valueGroupProperty.ValueKind != JsonValueKind.Null) { - iteration.ValueGroup.AddRange(jObject["valueGroup"].ToObject>()); + foreach(var element in valueGroupProperty.EnumerateArray()) + { + iteration.ValueGroup.Add(element.GetGuid()); + } } return iteration; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs index 16ad67577..c8e8447f2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,163 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class IterationSetupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.IterationSetup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var iterationSetup = new CDP4Common.DTO.IterationSetup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the IterationSetupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - iterationSetup.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["createdOn"].IsNullOrEmpty()) + var iterationSetup = new CDP4Common.DTO.IterationSetup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - iterationSetup.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["description"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("description"u8, out var descriptionProperty)) { - iterationSetup.Description = jObject["description"].ToObject(); + if(descriptionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale description property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.Description = descriptionProperty.GetString(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - iterationSetup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + iterationSetup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - iterationSetup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + iterationSetup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["frozenOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("frozenOn"u8, out var frozenOnProperty)) { - iterationSetup.FrozenOn = jObject["frozenOn"].ToObject(); + if(frozenOnProperty.ValueKind == JsonValueKind.Null) + { + iterationSetup.FrozenOn = null; + } + else + { + iterationSetup.FrozenOn = frozenOnProperty.GetDateTime(); + } } - if (!jObject["isDeleted"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeleted"u8, out var isDeletedProperty)) { - iterationSetup.IsDeleted = jObject["isDeleted"].ToObject(); + if(isDeletedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeleted property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.IsDeleted = isDeletedProperty.GetBoolean(); + } } - if (!jObject["iterationIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("iterationIid"u8, out var iterationIidProperty)) { - iterationSetup.IterationIid = jObject["iterationIid"].ToObject(); + if(iterationIidProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale iterationIid property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.IterationIid = iterationIidProperty.GetGuid(); + } } - if (!jObject["iterationNumber"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("iterationNumber"u8, out var iterationNumberProperty)) { - iterationSetup.IterationNumber = jObject["iterationNumber"].ToObject(); + if(iterationNumberProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale iterationNumber property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.IterationNumber = iterationNumberProperty.GetInt32(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - iterationSetup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["sourceIterationSetup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceIterationSetup"u8, out var sourceIterationSetupProperty)) { - iterationSetup.SourceIterationSetup = jObject["sourceIterationSetup"].ToObject(); + if(sourceIterationSetupProperty.ValueKind == JsonValueKind.Null) + { + iterationSetup.SourceIterationSetup = null; + } + else + { + iterationSetup.SourceIterationSetup = sourceIterationSetupProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - iterationSetup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the iterationSetup {id} is null", iterationSetup.Iid); + } + else + { + iterationSetup.ThingPreference = thingPreferenceProperty.GetString(); + } } return iterationSetup; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs index d2f22db3a..9cc1bca7b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,163 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class LinearConversionUnitResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var linearConversionUnit = new CDP4Common.DTO.LinearConversionUnit(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the LinearConversionUnitResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - linearConversionUnit.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var linearConversionUnit = new CDP4Common.DTO.LinearConversionUnit(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - linearConversionUnit.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + linearConversionUnit.Alias.Add(element.GetGuid()); + } } - if (!jObject["conversionFactor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("conversionFactor"u8, out var conversionFactorProperty)) { - linearConversionUnit.ConversionFactor = jObject["conversionFactor"].ToObject(); + if(conversionFactorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale conversionFactor property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.ConversionFactor = conversionFactorProperty.GetString(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - linearConversionUnit.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + linearConversionUnit.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - linearConversionUnit.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + linearConversionUnit.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - linearConversionUnit.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + linearConversionUnit.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - linearConversionUnit.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + linearConversionUnit.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - linearConversionUnit.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - linearConversionUnit.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - linearConversionUnit.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.Name = nameProperty.GetString(); + } } - if (!jObject["referenceUnit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceUnit"u8, out var referenceUnitProperty)) { - linearConversionUnit.ReferenceUnit = jObject["referenceUnit"].ToObject(); + if(referenceUnitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referenceUnit property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.ReferenceUnit = referenceUnitProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - linearConversionUnit.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - linearConversionUnit.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + } + else + { + linearConversionUnit.ThingPreference = thingPreferenceProperty.GetString(); + } } return linearConversionUnit; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs index 3f57890f2..b36348479 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,123 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class LogEntryChangelogItemResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var logEntryChangelogItem = new CDP4Common.DTO.LogEntryChangelogItem(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the LogEntryChangelogItemResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - logEntryChangelogItem.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["affectedItemIid"].IsNullOrEmpty()) + var logEntryChangelogItem = new CDP4Common.DTO.LogEntryChangelogItem(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("affectedItemIid"u8, out var affectedItemIidProperty)) { - logEntryChangelogItem.AffectedItemIid = jObject["affectedItemIid"].ToObject(); + if(affectedItemIidProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale affectedItemIid property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + } + else + { + logEntryChangelogItem.AffectedItemIid = affectedItemIidProperty.GetGuid(); + } } - if (!jObject["affectedReferenceIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("affectedReferenceIid"u8, out var affectedReferenceIidProperty) && affectedReferenceIidProperty.ValueKind != JsonValueKind.Null) { - logEntryChangelogItem.AffectedReferenceIid.AddRange(jObject["affectedReferenceIid"].ToObject>()); + foreach(var element in affectedReferenceIidProperty.EnumerateArray()) + { + logEntryChangelogItem.AffectedReferenceIid.Add(element.GetGuid()); + } } - if (!jObject["changeDescription"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("changeDescription"u8, out var changeDescriptionProperty)) { - logEntryChangelogItem.ChangeDescription = jObject["changeDescription"].ToObject(); + if(changeDescriptionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale changeDescription property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + } + else + { + logEntryChangelogItem.ChangeDescription = changeDescriptionProperty.GetString(); + } } - if (!jObject["changelogKind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("changelogKind"u8, out var changelogKindProperty)) { - logEntryChangelogItem.ChangelogKind = jObject["changelogKind"].ToObject(); + if(changelogKindProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale changelogKind property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + } + else + { + logEntryChangelogItem.ChangelogKind = LogEntryChangelogItemKindDeserializer.Deserialize(changelogKindProperty); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - logEntryChangelogItem.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + logEntryChangelogItem.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - logEntryChangelogItem.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + logEntryChangelogItem.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - logEntryChangelogItem.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + } + else + { + logEntryChangelogItem.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - logEntryChangelogItem.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + } + else + { + logEntryChangelogItem.ThingPreference = thingPreferenceProperty.GetString(); + } } return logEntryChangelogItem; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs index d4eeb426b..e7e3ecfe7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,161 +28,307 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class LogarithmicScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var logarithmicScale = new CDP4Common.DTO.LogarithmicScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the LogarithmicScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - logarithmicScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var logarithmicScale = new CDP4Common.DTO.LogarithmicScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + logarithmicScale.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + logarithmicScale.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + logarithmicScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + logarithmicScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["exponent"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("exponent"u8, out var exponentProperty)) { - logarithmicScale.Exponent = jObject["exponent"].ToObject(); + if(exponentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale exponent property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.Exponent = exponentProperty.GetString(); + } } - if (!jObject["factor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("factor"u8, out var factorProperty)) { - logarithmicScale.Factor = jObject["factor"].ToObject(); + if(factorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale factor property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.Factor = factorProperty.GetString(); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + logarithmicScale.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - logarithmicScale.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isMaximumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMaximumInclusive"u8, out var isMaximumInclusiveProperty)) { - logarithmicScale.IsMaximumInclusive = jObject["isMaximumInclusive"].ToObject(); + if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMaximumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.IsMaximumInclusive = isMaximumInclusiveProperty.GetBoolean(); + } } - if (!jObject["isMinimumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMinimumInclusive"u8, out var isMinimumInclusiveProperty)) { - logarithmicScale.IsMinimumInclusive = jObject["isMinimumInclusive"].ToObject(); + if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMinimumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.IsMinimumInclusive = isMinimumInclusiveProperty.GetBoolean(); + } } - if (!jObject["logarithmBase"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("logarithmBase"u8, out var logarithmBaseProperty)) { - logarithmicScale.LogarithmBase = jObject["logarithmBase"].ToObject(); + if(logarithmBaseProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale logarithmBase property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.LogarithmBase = LogarithmBaseKindDeserializer.Deserialize(logarithmBaseProperty); + } } - if (!jObject["mappingToReferenceScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("mappingToReferenceScale"u8, out var mappingToReferenceScaleProperty) && mappingToReferenceScaleProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.MappingToReferenceScale.AddRange(jObject["mappingToReferenceScale"].ToObject>()); + foreach(var element in mappingToReferenceScaleProperty.EnumerateArray()) + { + logarithmicScale.MappingToReferenceScale.Add(element.GetGuid()); + } } - if (!jObject["maximumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maximumPermissibleValue"u8, out var maximumPermissibleValueProperty)) { - logarithmicScale.MaximumPermissibleValue = jObject["maximumPermissibleValue"].ToObject(); + if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maximumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.MaximumPermissibleValue = maximumPermissibleValueProperty.GetString(); + } } - if (!jObject["minimumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minimumPermissibleValue"u8, out var minimumPermissibleValueProperty)) { - logarithmicScale.MinimumPermissibleValue = jObject["minimumPermissibleValue"].ToObject(); + if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minimumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.MinimumPermissibleValue = minimumPermissibleValueProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - logarithmicScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - logarithmicScale.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.Name = nameProperty.GetString(); + } } - if (!jObject["negativeValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("negativeValueConnotation"u8, out var negativeValueConnotationProperty)) { - logarithmicScale.NegativeValueConnotation = jObject["negativeValueConnotation"].ToObject(); + if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale negativeValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.NegativeValueConnotation = negativeValueConnotationProperty.GetString(); + } } - if (!jObject["numberSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("numberSet"u8, out var numberSetProperty)) { - logarithmicScale.NumberSet = jObject["numberSet"].ToObject(); + if(numberSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale numberSet property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.NumberSet = NumberSetKindDeserializer.Deserialize(numberSetProperty); + } } - if (!jObject["positiveValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("positiveValueConnotation"u8, out var positiveValueConnotationProperty)) { - logarithmicScale.PositiveValueConnotation = jObject["positiveValueConnotation"].ToObject(); + if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale positiveValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.PositiveValueConnotation = positiveValueConnotationProperty.GetString(); + } } - if (!jObject["referenceQuantityKind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceQuantityKind"u8, out var referenceQuantityKindProperty)) { - logarithmicScale.ReferenceQuantityKind = jObject["referenceQuantityKind"].ToObject(); + if(referenceQuantityKindProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referenceQuantityKind property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.ReferenceQuantityKind = referenceQuantityKindProperty.GetGuid(); + } } - if (!jObject["referenceQuantityValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceQuantityValue"u8, out var referenceQuantityValueProperty) && referenceQuantityValueProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.ReferenceQuantityValue.AddRange(jObject["referenceQuantityValue"].ToObject>()); + foreach(var element in referenceQuantityValueProperty.EnumerateArray()) + { + logarithmicScale.ReferenceQuantityValue.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - logarithmicScale.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - logarithmicScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - logarithmicScale.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the logarithmicScale {id} is null", logarithmicScale.Iid); + } + else + { + logarithmicScale.Unit = unitProperty.GetGuid(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty) && valueDefinitionProperty.ValueKind != JsonValueKind.Null) { - logarithmicScale.ValueDefinition.AddRange(jObject["valueDefinition"].ToObject>()); + foreach(var element in valueDefinitionProperty.EnumerateArray()) + { + logarithmicScale.ValueDefinition.Add(element.GetGuid()); + } } return logarithmicScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs index 6b91d30e1..dbb65b2f6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class MappingToReferenceScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var mappingToReferenceScale = new CDP4Common.DTO.MappingToReferenceScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the MappingToReferenceScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - mappingToReferenceScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["dependentScaleValue"].IsNullOrEmpty()) + var mappingToReferenceScale = new CDP4Common.DTO.MappingToReferenceScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("dependentScaleValue"u8, out var dependentScaleValueProperty)) { - mappingToReferenceScale.DependentScaleValue = jObject["dependentScaleValue"].ToObject(); + if(dependentScaleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale dependentScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + } + else + { + mappingToReferenceScale.DependentScaleValue = dependentScaleValueProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - mappingToReferenceScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + mappingToReferenceScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - mappingToReferenceScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + mappingToReferenceScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - mappingToReferenceScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + } + else + { + mappingToReferenceScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["referenceScaleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceScaleValue"u8, out var referenceScaleValueProperty)) { - mappingToReferenceScale.ReferenceScaleValue = jObject["referenceScaleValue"].ToObject(); + if(referenceScaleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referenceScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + } + else + { + mappingToReferenceScale.ReferenceScaleValue = referenceScaleValueProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - mappingToReferenceScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + } + else + { + mappingToReferenceScale.ThingPreference = thingPreferenceProperty.GetString(); + } } return mappingToReferenceScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs index b50df3680..46817fdaf 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,171 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ModelLogEntryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var modelLogEntry = new CDP4Common.DTO.ModelLogEntry(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ModelLogEntryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - modelLogEntry.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["affectedDomainIid"].IsNullOrEmpty()) + var modelLogEntry = new CDP4Common.DTO.ModelLogEntry(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("affectedDomainIid"u8, out var affectedDomainIidProperty) && affectedDomainIidProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.AffectedDomainIid.AddRange(jObject["affectedDomainIid"].ToObject>()); + foreach(var element in affectedDomainIidProperty.EnumerateArray()) + { + modelLogEntry.AffectedDomainIid.Add(element.GetGuid()); + } } - if (!jObject["affectedItemIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("affectedItemIid"u8, out var affectedItemIidProperty) && affectedItemIidProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.AffectedItemIid.AddRange(jObject["affectedItemIid"].ToObject>()); + foreach(var element in affectedItemIidProperty.EnumerateArray()) + { + modelLogEntry.AffectedItemIid.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - modelLogEntry.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + modelLogEntry.Author = null; + } + else + { + modelLogEntry.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + modelLogEntry.Category.Add(element.GetGuid()); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - modelLogEntry.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - modelLogEntry.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + modelLogEntry.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + modelLogEntry.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - modelLogEntry.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["level"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("level"u8, out var levelProperty)) { - modelLogEntry.Level = jObject["level"].ToObject(); + if(levelProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale level property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.Level = LogLevelKindDeserializer.Deserialize(levelProperty); + } } - if (!jObject["logEntryChangelogItem"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("logEntryChangelogItem"u8, out var logEntryChangelogItemProperty) && logEntryChangelogItemProperty.ValueKind != JsonValueKind.Null) { - modelLogEntry.LogEntryChangelogItem.AddRange(jObject["logEntryChangelogItem"].ToObject>()); + foreach(var element in logEntryChangelogItemProperty.EnumerateArray()) + { + modelLogEntry.LogEntryChangelogItem.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - modelLogEntry.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - modelLogEntry.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the modelLogEntry {id} is null", modelLogEntry.Iid); + } + else + { + modelLogEntry.ThingPreference = thingPreferenceProperty.GetString(); + } } return modelLogEntry; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs index 3b5e3f44c..5490153a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,146 +28,232 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ModelReferenceDataLibraryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var modelReferenceDataLibrary = new CDP4Common.DTO.ModelReferenceDataLibrary(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ModelReferenceDataLibraryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - modelReferenceDataLibrary.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var modelReferenceDataLibrary = new CDP4Common.DTO.ModelReferenceDataLibrary(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Alias.Add(element.GetGuid()); + } } - if (!jObject["baseQuantityKind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("baseQuantityKind"u8, out var baseQuantityKindProperty)) { - modelReferenceDataLibrary.BaseQuantityKind.AddRange(jObject["baseQuantityKind"].ToOrderedItemCollection()); + modelReferenceDataLibrary.BaseQuantityKind.AddRange(baseQuantityKindProperty.ToOrderedItemCollection()); } - if (!jObject["baseUnit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("baseUnit"u8, out var baseUnitProperty) && baseUnitProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.BaseUnit.AddRange(jObject["baseUnit"].ToObject>()); + foreach(var element in baseUnitProperty.EnumerateArray()) + { + modelReferenceDataLibrary.BaseUnit.Add(element.GetGuid()); + } } - if (!jObject["constant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("constant"u8, out var constantProperty) && constantProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Constant.AddRange(jObject["constant"].ToObject>()); + foreach(var element in constantProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Constant.Add(element.GetGuid()); + } } - if (!jObject["definedCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definedCategory"u8, out var definedCategoryProperty) && definedCategoryProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.DefinedCategory.AddRange(jObject["definedCategory"].ToObject>()); + foreach(var element in definedCategoryProperty.EnumerateArray()) + { + modelReferenceDataLibrary.DefinedCategory.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + modelReferenceDataLibrary.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + modelReferenceDataLibrary.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fileType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fileType"u8, out var fileTypeProperty) && fileTypeProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.FileType.AddRange(jObject["fileType"].ToObject>()); + foreach(var element in fileTypeProperty.EnumerateArray()) + { + modelReferenceDataLibrary.FileType.Add(element.GetGuid()); + } } - if (!jObject["glossary"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("glossary"u8, out var glossaryProperty) && glossaryProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Glossary.AddRange(jObject["glossary"].ToObject>()); + foreach(var element in glossaryProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Glossary.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + modelReferenceDataLibrary.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - modelReferenceDataLibrary.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + } + else + { + modelReferenceDataLibrary.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - modelReferenceDataLibrary.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + } + else + { + modelReferenceDataLibrary.Name = nameProperty.GetString(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty) && parameterTypeProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.ParameterType.AddRange(jObject["parameterType"].ToObject>()); + foreach(var element in parameterTypeProperty.EnumerateArray()) + { + modelReferenceDataLibrary.ParameterType.Add(element.GetGuid()); + } } - if (!jObject["referenceSource"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceSource"u8, out var referenceSourceProperty) && referenceSourceProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.ReferenceSource.AddRange(jObject["referenceSource"].ToObject>()); + foreach(var element in referenceSourceProperty.EnumerateArray()) + { + modelReferenceDataLibrary.ReferenceSource.Add(element.GetGuid()); + } } - if (!jObject["requiredRdl"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requiredRdl"u8, out var requiredRdlProperty)) { - modelReferenceDataLibrary.RequiredRdl = jObject["requiredRdl"].ToObject(); + if(requiredRdlProperty.ValueKind == JsonValueKind.Null) + { + modelReferenceDataLibrary.RequiredRdl = null; + } + else + { + modelReferenceDataLibrary.RequiredRdl = requiredRdlProperty.GetGuid(); + } } - if (!jObject["rule"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("rule"u8, out var ruleProperty) && ruleProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Rule.AddRange(jObject["rule"].ToObject>()); + foreach(var element in ruleProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Rule.Add(element.GetGuid()); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty) && scaleProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Scale.AddRange(jObject["scale"].ToObject>()); + foreach(var element in scaleProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Scale.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - modelReferenceDataLibrary.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + } + else + { + modelReferenceDataLibrary.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - modelReferenceDataLibrary.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + } + else + { + modelReferenceDataLibrary.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty) && unitProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.Unit.AddRange(jObject["unit"].ToObject>()); + foreach(var element in unitProperty.EnumerateArray()) + { + modelReferenceDataLibrary.Unit.Add(element.GetGuid()); + } } - if (!jObject["unitPrefix"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unitPrefix"u8, out var unitPrefixProperty) && unitPrefixProperty.ValueKind != JsonValueKind.Null) { - modelReferenceDataLibrary.UnitPrefix.AddRange(jObject["unitPrefix"].ToObject>()); + foreach(var element in unitPrefixProperty.EnumerateArray()) + { + modelReferenceDataLibrary.UnitPrefix.Add(element.GetGuid()); + } } return modelReferenceDataLibrary; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs index 498265b12..9f834b6c7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ModellingThingReferenceResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var modellingThingReference = new CDP4Common.DTO.ModellingThingReference(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ModellingThingReferenceResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - modellingThingReference.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var modellingThingReference = new CDP4Common.DTO.ModellingThingReference(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - modellingThingReference.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + modellingThingReference.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - modellingThingReference.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + modellingThingReference.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - modellingThingReference.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the modellingThingReference {id} is null", modellingThingReference.Iid); + } + else + { + modellingThingReference.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["referencedRevisionNumber"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedRevisionNumber"u8, out var referencedRevisionNumberProperty)) { - modellingThingReference.ReferencedRevisionNumber = jObject["referencedRevisionNumber"].ToObject(); + if(referencedRevisionNumberProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referencedRevisionNumber property of the modellingThingReference {id} is null", modellingThingReference.Iid); + } + else + { + modellingThingReference.ReferencedRevisionNumber = referencedRevisionNumberProperty.GetInt32(); + } } - if (!jObject["referencedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedThing"u8, out var referencedThingProperty)) { - modellingThingReference.ReferencedThing = jObject["referencedThing"].ToObject(); + if(referencedThingProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referencedThing property of the modellingThingReference {id} is null", modellingThingReference.Iid); + } + else + { + modellingThingReference.ReferencedThing = referencedThingProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - modellingThingReference.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the modellingThingReference {id} is null", modellingThingReference.Iid); + } + else + { + modellingThingReference.ThingPreference = thingPreferenceProperty.GetString(); + } } return modellingThingReference; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs index 868696aa7..53831176a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class MultiRelationshipResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.MultiRelationship FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.MultiRelationship FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var multiRelationship = new CDP4Common.DTO.MultiRelationship(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the MultiRelationshipResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - multiRelationship.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var multiRelationship = new CDP4Common.DTO.MultiRelationship(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - multiRelationship.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + multiRelationship.Category.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - multiRelationship.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + multiRelationship.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - multiRelationship.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + multiRelationship.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - multiRelationship.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the multiRelationship {id} is null", multiRelationship.Iid); + } + else + { + multiRelationship.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - multiRelationship.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the multiRelationship {id} is null", multiRelationship.Iid); + } + else + { + multiRelationship.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - multiRelationship.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the multiRelationship {id} is null", multiRelationship.Iid); + } + else + { + multiRelationship.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValue"u8, out var parameterValueProperty) && parameterValueProperty.ValueKind != JsonValueKind.Null) { - multiRelationship.ParameterValue.AddRange(jObject["parameterValue"].ToObject>()); + foreach(var element in parameterValueProperty.EnumerateArray()) + { + multiRelationship.ParameterValue.Add(element.GetGuid()); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - multiRelationship.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + multiRelationship.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - multiRelationship.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the multiRelationship {id} is null", multiRelationship.Iid); + } + else + { + multiRelationship.ThingPreference = thingPreferenceProperty.GetString(); + } } return multiRelationship; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs index 923a693e7..8c980774c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,183 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class MultiRelationshipRuleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var multiRelationshipRule = new CDP4Common.DTO.MultiRelationshipRule(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the MultiRelationshipRuleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - multiRelationshipRule.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var multiRelationshipRule = new CDP4Common.DTO.MultiRelationshipRule(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + multiRelationshipRule.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + multiRelationshipRule.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + multiRelationshipRule.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + multiRelationshipRule.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + multiRelationshipRule.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - multiRelationshipRule.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["maxRelated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maxRelated"u8, out var maxRelatedProperty)) { - multiRelationshipRule.MaxRelated = jObject["maxRelated"].ToObject(); + if(maxRelatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maxRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.MaxRelated = maxRelatedProperty.GetInt32(); + } } - if (!jObject["minRelated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minRelated"u8, out var minRelatedProperty)) { - multiRelationshipRule.MinRelated = jObject["minRelated"].ToObject(); + if(minRelatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.MinRelated = minRelatedProperty.GetInt32(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - multiRelationshipRule.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - multiRelationshipRule.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.Name = nameProperty.GetString(); + } } - if (!jObject["relatedCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedCategory"u8, out var relatedCategoryProperty) && relatedCategoryProperty.ValueKind != JsonValueKind.Null) { - multiRelationshipRule.RelatedCategory.AddRange(jObject["relatedCategory"].ToObject>()); + foreach(var element in relatedCategoryProperty.EnumerateArray()) + { + multiRelationshipRule.RelatedCategory.Add(element.GetGuid()); + } } - if (!jObject["relationshipCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relationshipCategory"u8, out var relationshipCategoryProperty)) { - multiRelationshipRule.RelationshipCategory = jObject["relationshipCategory"].ToObject(); + if(relationshipCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale relationshipCategory property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.RelationshipCategory = relationshipCategoryProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - multiRelationshipRule.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - multiRelationshipRule.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + } + else + { + multiRelationshipRule.ThingPreference = thingPreferenceProperty.GetString(); + } } return multiRelationshipRule; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs index 0d5981694..afc4b90e4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class NaturalLanguageResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var naturalLanguage = new CDP4Common.DTO.NaturalLanguage(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the NaturalLanguageResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - naturalLanguage.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var naturalLanguage = new CDP4Common.DTO.NaturalLanguage(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - naturalLanguage.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + naturalLanguage.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - naturalLanguage.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + naturalLanguage.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - naturalLanguage.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the naturalLanguage {id} is null", naturalLanguage.Iid); + } + else + { + naturalLanguage.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - naturalLanguage.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the naturalLanguage {id} is null", naturalLanguage.Iid); + } + else + { + naturalLanguage.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - naturalLanguage.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the naturalLanguage {id} is null", naturalLanguage.Iid); + } + else + { + naturalLanguage.Name = nameProperty.GetString(); + } } - if (!jObject["nativeName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("nativeName"u8, out var nativeNameProperty)) { - naturalLanguage.NativeName = jObject["nativeName"].ToObject(); + if(nativeNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale nativeName property of the naturalLanguage {id} is null", naturalLanguage.Iid); + } + else + { + naturalLanguage.NativeName = nativeNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - naturalLanguage.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the naturalLanguage {id} is null", naturalLanguage.Iid); + } + else + { + naturalLanguage.ThingPreference = thingPreferenceProperty.GetString(); + } } return naturalLanguage; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs index 271d8daf5..d7eb62e54 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,116 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class NestedElementResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.NestedElement FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.NestedElement FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var nestedElement = new CDP4Common.DTO.NestedElement(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the NestedElementResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - nestedElement.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["elementUsage"].IsNullOrEmpty()) + var nestedElement = new CDP4Common.DTO.NestedElement(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("elementUsage"u8, out var elementUsageProperty)) { - nestedElement.ElementUsage.AddRange(jObject["elementUsage"].ToOrderedItemCollection()); + nestedElement.ElementUsage.AddRange(elementUsageProperty.ToOrderedItemCollection()); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - nestedElement.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + nestedElement.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - nestedElement.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + nestedElement.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isVolatile"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isVolatile"u8, out var isVolatileProperty)) { - nestedElement.IsVolatile = jObject["isVolatile"].ToObject(); + if(isVolatileProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isVolatile property of the nestedElement {id} is null", nestedElement.Iid); + } + else + { + nestedElement.IsVolatile = isVolatileProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - nestedElement.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the nestedElement {id} is null", nestedElement.Iid); + } + else + { + nestedElement.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["nestedParameter"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("nestedParameter"u8, out var nestedParameterProperty) && nestedParameterProperty.ValueKind != JsonValueKind.Null) { - nestedElement.NestedParameter.AddRange(jObject["nestedParameter"].ToObject>()); + foreach(var element in nestedParameterProperty.EnumerateArray()) + { + nestedElement.NestedParameter.Add(element.GetGuid()); + } } - if (!jObject["rootElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("rootElement"u8, out var rootElementProperty)) { - nestedElement.RootElement = jObject["rootElement"].ToObject(); + if(rootElementProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale rootElement property of the nestedElement {id} is null", nestedElement.Iid); + } + else + { + nestedElement.RootElement = rootElementProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - nestedElement.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the nestedElement {id} is null", nestedElement.Iid); + } + else + { + nestedElement.ThingPreference = thingPreferenceProperty.GetString(); + } } return nestedElement; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs index 985c18012..30c147689 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,151 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class NestedParameterResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.NestedParameter FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var nestedParameter = new CDP4Common.DTO.NestedParameter(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the NestedParameterResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - nestedParameter.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actualState"].IsNullOrEmpty()) + var nestedParameter = new CDP4Common.DTO.NestedParameter(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("actualState"u8, out var actualStateProperty)) { - nestedParameter.ActualState = jObject["actualState"].ToObject(); + if(actualStateProperty.ValueKind == JsonValueKind.Null) + { + nestedParameter.ActualState = null; + } + else + { + nestedParameter.ActualState = actualStateProperty.GetGuid(); + } } - if (!jObject["actualValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("actualValue"u8, out var actualValueProperty)) { - nestedParameter.ActualValue = jObject["actualValue"].ToObject(); + if(actualValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale actualValue property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.ActualValue = actualValueProperty.GetString(); + } } - if (!jObject["associatedParameter"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("associatedParameter"u8, out var associatedParameterProperty)) { - nestedParameter.AssociatedParameter = jObject["associatedParameter"].ToObject(); + if(associatedParameterProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale associatedParameter property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.AssociatedParameter = associatedParameterProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - nestedParameter.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + nestedParameter.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - nestedParameter.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + nestedParameter.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["formula"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("formula"u8, out var formulaProperty)) { - nestedParameter.Formula = jObject["formula"].ToObject(); + if(formulaProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale formula property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.Formula = formulaProperty.GetString(); + } } - if (!jObject["isVolatile"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isVolatile"u8, out var isVolatileProperty)) { - nestedParameter.IsVolatile = jObject["isVolatile"].ToObject(); + if(isVolatileProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isVolatile property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.IsVolatile = isVolatileProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - nestedParameter.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - nestedParameter.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - nestedParameter.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the nestedParameter {id} is null", nestedParameter.Iid); + } + else + { + nestedParameter.ThingPreference = thingPreferenceProperty.GetString(); + } } return nestedParameter; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs index 6dbdea5c8..185f66df2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,61 +28,91 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class NotExpressionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.NotExpression FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.NotExpression FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var notExpression = new CDP4Common.DTO.NotExpression(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the NotExpressionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - notExpression.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var notExpression = new CDP4Common.DTO.NotExpression(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - notExpression.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + notExpression.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - notExpression.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + notExpression.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - notExpression.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the notExpression {id} is null", notExpression.Iid); + } + else + { + notExpression.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["term"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("term"u8, out var termProperty)) { - notExpression.Term = jObject["term"].ToObject(); + if(termProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale term property of the notExpression {id} is null", notExpression.Iid); + } + else + { + notExpression.Term = termProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - notExpression.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the notExpression {id} is null", notExpression.Iid); + } + else + { + notExpression.ThingPreference = thingPreferenceProperty.GetString(); + } } return notExpression; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs index e02366310..72dd27d06 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,143 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OptionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Option FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Option FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var option = new CDP4Common.DTO.Option(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OptionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - option.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var option = new CDP4Common.DTO.Option(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - option.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + option.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - option.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + option.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - option.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + option.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - option.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + option.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - option.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + option.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - option.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + option.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - option.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the option {id} is null", option.Iid); + } + else + { + option.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - option.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the option {id} is null", option.Iid); + } + else + { + option.Name = nameProperty.GetString(); + } } - if (!jObject["nestedElement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("nestedElement"u8, out var nestedElementProperty) && nestedElementProperty.ValueKind != JsonValueKind.Null) { - option.NestedElement.AddRange(jObject["nestedElement"].ToObject>()); + foreach(var element in nestedElementProperty.EnumerateArray()) + { + option.NestedElement.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - option.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the option {id} is null", option.Iid); + } + else + { + option.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - option.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the option {id} is null", option.Iid); + } + else + { + option.ThingPreference = thingPreferenceProperty.GetString(); + } } return option; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs index d91451ac6..596b989ac 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,61 +28,87 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OrExpressionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.OrExpression FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.OrExpression FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var orExpression = new CDP4Common.DTO.OrExpression(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OrExpressionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - orExpression.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var orExpression = new CDP4Common.DTO.OrExpression(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - orExpression.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + orExpression.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - orExpression.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + orExpression.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - orExpression.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the orExpression {id} is null", orExpression.Iid); + } + else + { + orExpression.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["term"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("term"u8, out var termProperty) && termProperty.ValueKind != JsonValueKind.Null) { - orExpression.Term.AddRange(jObject["term"].ToObject>()); + foreach(var element in termProperty.EnumerateArray()) + { + orExpression.Term.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - orExpression.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the orExpression {id} is null", orExpression.Iid); + } + else + { + orExpression.ThingPreference = thingPreferenceProperty.GetString(); + } } return orExpression; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs index 7d568acd9..fc3cb2148 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,141 +28,263 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OrdinalScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.OrdinalScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var ordinalScale = new CDP4Common.DTO.OrdinalScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OrdinalScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - ordinalScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var ordinalScale = new CDP4Common.DTO.OrdinalScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + ordinalScale.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + ordinalScale.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + ordinalScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + ordinalScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + ordinalScale.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - ordinalScale.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isMaximumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMaximumInclusive"u8, out var isMaximumInclusiveProperty)) { - ordinalScale.IsMaximumInclusive = jObject["isMaximumInclusive"].ToObject(); + if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMaximumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.IsMaximumInclusive = isMaximumInclusiveProperty.GetBoolean(); + } } - if (!jObject["isMinimumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMinimumInclusive"u8, out var isMinimumInclusiveProperty)) { - ordinalScale.IsMinimumInclusive = jObject["isMinimumInclusive"].ToObject(); + if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMinimumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.IsMinimumInclusive = isMinimumInclusiveProperty.GetBoolean(); + } } - if (!jObject["mappingToReferenceScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("mappingToReferenceScale"u8, out var mappingToReferenceScaleProperty) && mappingToReferenceScaleProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.MappingToReferenceScale.AddRange(jObject["mappingToReferenceScale"].ToObject>()); + foreach(var element in mappingToReferenceScaleProperty.EnumerateArray()) + { + ordinalScale.MappingToReferenceScale.Add(element.GetGuid()); + } } - if (!jObject["maximumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maximumPermissibleValue"u8, out var maximumPermissibleValueProperty)) { - ordinalScale.MaximumPermissibleValue = jObject["maximumPermissibleValue"].ToObject(); + if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maximumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.MaximumPermissibleValue = maximumPermissibleValueProperty.GetString(); + } } - if (!jObject["minimumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minimumPermissibleValue"u8, out var minimumPermissibleValueProperty)) { - ordinalScale.MinimumPermissibleValue = jObject["minimumPermissibleValue"].ToObject(); + if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minimumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.MinimumPermissibleValue = minimumPermissibleValueProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - ordinalScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - ordinalScale.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.Name = nameProperty.GetString(); + } } - if (!jObject["negativeValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("negativeValueConnotation"u8, out var negativeValueConnotationProperty)) { - ordinalScale.NegativeValueConnotation = jObject["negativeValueConnotation"].ToObject(); + if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale negativeValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.NegativeValueConnotation = negativeValueConnotationProperty.GetString(); + } } - if (!jObject["numberSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("numberSet"u8, out var numberSetProperty)) { - ordinalScale.NumberSet = jObject["numberSet"].ToObject(); + if(numberSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale numberSet property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.NumberSet = NumberSetKindDeserializer.Deserialize(numberSetProperty); + } } - if (!jObject["positiveValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("positiveValueConnotation"u8, out var positiveValueConnotationProperty)) { - ordinalScale.PositiveValueConnotation = jObject["positiveValueConnotation"].ToObject(); + if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale positiveValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.PositiveValueConnotation = positiveValueConnotationProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - ordinalScale.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - ordinalScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - ordinalScale.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.Unit = unitProperty.GetGuid(); + } } - if (!jObject["useShortNameValues"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("useShortNameValues"u8, out var useShortNameValuesProperty)) { - ordinalScale.UseShortNameValues = jObject["useShortNameValues"].ToObject(); + if(useShortNameValuesProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale useShortNameValues property of the ordinalScale {id} is null", ordinalScale.Iid); + } + else + { + ordinalScale.UseShortNameValues = useShortNameValuesProperty.GetBoolean(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty) && valueDefinitionProperty.ValueKind != JsonValueKind.Null) { - ordinalScale.ValueDefinition.AddRange(jObject["valueDefinition"].ToObject>()); + foreach(var element in valueDefinitionProperty.EnumerateArray()) + { + ordinalScale.ValueDefinition.Add(element.GetGuid()); + } } return ordinalScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs index fc82ad34b..2e50a992b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OrganizationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Organization FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var organization = new CDP4Common.DTO.Organization(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OrganizationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - organization.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var organization = new CDP4Common.DTO.Organization(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - organization.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + organization.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - organization.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + organization.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - organization.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the organization {id} is null", organization.Iid); + } + else + { + organization.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - organization.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the organization {id} is null", organization.Iid); + } + else + { + organization.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - organization.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the organization {id} is null", organization.Iid); + } + else + { + organization.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - organization.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the organization {id} is null", organization.Iid); + } + else + { + organization.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - organization.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the organization {id} is null", organization.Iid); + } + else + { + organization.ThingPreference = thingPreferenceProperty.GetString(); + } } return organization; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs index 5fa3f94d0..560cbfa06 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,61 +28,91 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OrganizationalParticipantResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.OrganizationalParticipant FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.OrganizationalParticipant FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var organizationalParticipant = new CDP4Common.DTO.OrganizationalParticipant(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OrganizationalParticipantResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - organizationalParticipant.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var organizationalParticipant = new CDP4Common.DTO.OrganizationalParticipant(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - organizationalParticipant.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + organizationalParticipant.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - organizationalParticipant.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + organizationalParticipant.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - organizationalParticipant.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + } + else + { + organizationalParticipant.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["organization"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organization"u8, out var organizationProperty)) { - organizationalParticipant.Organization = jObject["organization"].ToObject(); + if(organizationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale organization property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + } + else + { + organizationalParticipant.Organization = organizationProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - organizationalParticipant.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + } + else + { + organizationalParticipant.ThingPreference = thingPreferenceProperty.GetString(); + } } return organizationalParticipant; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs index fad8d6e57..a0c000fb4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,126 +28,243 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class OwnedStyleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.OwnedStyle FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.OwnedStyle FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var ownedStyle = new CDP4Common.DTO.OwnedStyle(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the OwnedStyleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - ownedStyle.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var ownedStyle = new CDP4Common.DTO.OwnedStyle(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - ownedStyle.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + ownedStyle.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - ownedStyle.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + ownedStyle.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fillColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fillColor"u8, out var fillColorProperty)) { - ownedStyle.FillColor = jObject["fillColor"].ToObject(); + if(fillColorProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FillColor = null; + } + else + { + ownedStyle.FillColor = fillColorProperty.GetGuid(); + } } - if (!jObject["fillOpacity"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fillOpacity"u8, out var fillOpacityProperty)) { - ownedStyle.FillOpacity = jObject["fillOpacity"].ToObject(); + if(fillOpacityProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FillOpacity = null; + } + else + { + ownedStyle.FillOpacity = fillOpacityProperty.GetSingle(); + } } - if (!jObject["fontBold"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontBold"u8, out var fontBoldProperty)) { - ownedStyle.FontBold = jObject["fontBold"].ToObject(); + if(fontBoldProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontBold = null; + } + else + { + ownedStyle.FontBold = fontBoldProperty.GetBoolean(); + } } - if (!jObject["fontColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontColor"u8, out var fontColorProperty)) { - ownedStyle.FontColor = jObject["fontColor"].ToObject(); + if(fontColorProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontColor = null; + } + else + { + ownedStyle.FontColor = fontColorProperty.GetGuid(); + } } - if (!jObject["fontItalic"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontItalic"u8, out var fontItalicProperty)) { - ownedStyle.FontItalic = jObject["fontItalic"].ToObject(); + if(fontItalicProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontItalic = null; + } + else + { + ownedStyle.FontItalic = fontItalicProperty.GetBoolean(); + } } - if (!jObject["fontName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontName"u8, out var fontNameProperty)) { - ownedStyle.FontName = jObject["fontName"].ToObject(); + if(fontNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale fontName property of the ownedStyle {id} is null", ownedStyle.Iid); + } + else + { + ownedStyle.FontName = fontNameProperty.GetString(); + } } - if (!jObject["fontSize"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontSize"u8, out var fontSizeProperty)) { - ownedStyle.FontSize = jObject["fontSize"].ToObject(); + if(fontSizeProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontSize = null; + } + else + { + ownedStyle.FontSize = fontSizeProperty.GetSingle(); + } } - if (!jObject["fontStrokeThrough"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontStrokeThrough"u8, out var fontStrokeThroughProperty)) { - ownedStyle.FontStrokeThrough = jObject["fontStrokeThrough"].ToObject(); + if(fontStrokeThroughProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontStrokeThrough = null; + } + else + { + ownedStyle.FontStrokeThrough = fontStrokeThroughProperty.GetBoolean(); + } } - if (!jObject["fontUnderline"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontUnderline"u8, out var fontUnderlineProperty)) { - ownedStyle.FontUnderline = jObject["fontUnderline"].ToObject(); + if(fontUnderlineProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.FontUnderline = null; + } + else + { + ownedStyle.FontUnderline = fontUnderlineProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - ownedStyle.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the ownedStyle {id} is null", ownedStyle.Iid); + } + else + { + ownedStyle.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - ownedStyle.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the ownedStyle {id} is null", ownedStyle.Iid); + } + else + { + ownedStyle.Name = nameProperty.GetString(); + } } - if (!jObject["strokeColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeColor"u8, out var strokeColorProperty)) { - ownedStyle.StrokeColor = jObject["strokeColor"].ToObject(); + if(strokeColorProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.StrokeColor = null; + } + else + { + ownedStyle.StrokeColor = strokeColorProperty.GetGuid(); + } } - if (!jObject["strokeOpacity"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeOpacity"u8, out var strokeOpacityProperty)) { - ownedStyle.StrokeOpacity = jObject["strokeOpacity"].ToObject(); + if(strokeOpacityProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.StrokeOpacity = null; + } + else + { + ownedStyle.StrokeOpacity = strokeOpacityProperty.GetSingle(); + } } - if (!jObject["strokeWidth"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeWidth"u8, out var strokeWidthProperty)) { - ownedStyle.StrokeWidth = jObject["strokeWidth"].ToObject(); + if(strokeWidthProperty.ValueKind == JsonValueKind.Null) + { + ownedStyle.StrokeWidth = null; + } + else + { + ownedStyle.StrokeWidth = strokeWidthProperty.GetSingle(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - ownedStyle.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the ownedStyle {id} is null", ownedStyle.Iid); + } + else + { + ownedStyle.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["usedColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("usedColor"u8, out var usedColorProperty) && usedColorProperty.ValueKind != JsonValueKind.Null) { - ownedStyle.UsedColor.AddRange(jObject["usedColor"].ToObject>()); + foreach(var element in usedColorProperty.EnumerateArray()) + { + ownedStyle.UsedColor.Add(element.GetGuid()); + } } return ownedStyle; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs index 66ccfbaaa..80415d1e6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,140 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PageResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Page FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var page = new CDP4Common.DTO.Page(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PageResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - page.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var page = new CDP4Common.DTO.Page(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - page.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + page.Category.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - page.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the page {id} is null", page.Iid); + } + else + { + page.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - page.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + page.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - page.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + page.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - page.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the page {id} is null", page.Iid); + } + else + { + page.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - page.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the page {id} is null", page.Iid); + } + else + { + page.Name = nameProperty.GetString(); + } } - if (!jObject["note"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("note"u8, out var noteProperty)) { - page.Note.AddRange(jObject["note"].ToOrderedItemCollection()); + page.Note.AddRange(noteProperty.ToOrderedItemCollection()); } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - page.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the page {id} is null", page.Iid); + } + else + { + page.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - page.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the page {id} is null", page.Iid); + } + else + { + page.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - page.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the page {id} is null", page.Iid); + } + else + { + page.ThingPreference = thingPreferenceProperty.GetString(); + } } return page; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs index 5d624fd21..97c0a8da7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterGroupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterGroup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterGroup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterGroup = new CDP4Common.DTO.ParameterGroup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterGroupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterGroup.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["containingGroup"].IsNullOrEmpty()) + var parameterGroup = new CDP4Common.DTO.ParameterGroup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("containingGroup"u8, out var containingGroupProperty)) { - parameterGroup.ContainingGroup = jObject["containingGroup"].ToObject(); + if(containingGroupProperty.ValueKind == JsonValueKind.Null) + { + parameterGroup.ContainingGroup = null; + } + else + { + parameterGroup.ContainingGroup = containingGroupProperty.GetGuid(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterGroup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterGroup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterGroup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterGroup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterGroup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterGroup {id} is null", parameterGroup.Iid); + } + else + { + parameterGroup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - parameterGroup.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the parameterGroup {id} is null", parameterGroup.Iid); + } + else + { + parameterGroup.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterGroup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterGroup {id} is null", parameterGroup.Iid); + } + else + { + parameterGroup.ThingPreference = thingPreferenceProperty.GetString(); + } } return parameterGroup; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs index aabfdc220..1c54ce876 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,119 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterOverrideResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterOverride FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterOverride FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterOverride = new CDP4Common.DTO.ParameterOverride(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterOverrideResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterOverride.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var parameterOverride = new CDP4Common.DTO.ParameterOverride(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterOverride.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterOverride.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterOverride.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterOverride.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterOverride.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterOverride {id} is null", parameterOverride.Iid); + } + else + { + parameterOverride.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - parameterOverride.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the parameterOverride {id} is null", parameterOverride.Iid); + } + else + { + parameterOverride.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameter"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameter"u8, out var parameterProperty)) { - parameterOverride.Parameter = jObject["parameter"].ToObject(); + if(parameterProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameter property of the parameterOverride {id} is null", parameterOverride.Iid); + } + else + { + parameterOverride.Parameter = parameterProperty.GetGuid(); + } } - if (!jObject["parameterSubscription"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterSubscription"u8, out var parameterSubscriptionProperty) && parameterSubscriptionProperty.ValueKind != JsonValueKind.Null) { - parameterOverride.ParameterSubscription.AddRange(jObject["parameterSubscription"].ToObject>()); + foreach(var element in parameterSubscriptionProperty.EnumerateArray()) + { + parameterOverride.ParameterSubscription.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterOverride.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterOverride {id} is null", parameterOverride.Iid); + } + else + { + parameterOverride.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSet"u8, out var valueSetProperty) && valueSetProperty.ValueKind != JsonValueKind.Null) { - parameterOverride.ValueSet.AddRange(jObject["valueSet"].ToObject>()); + foreach(var element in valueSetProperty.EnumerateArray()) + { + parameterOverride.ValueSet.Add(element.GetGuid()); + } } return parameterOverride; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs index 99e36d494..431d85fbb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,124 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterOverrideValueSetResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterOverrideValueSet = new CDP4Common.DTO.ParameterOverrideValueSet(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - parameterOverrideValueSet.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the ParameterOverrideValueSetResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["computed"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterOverrideValueSet.Computed = SerializerHelper.ToValueArray(jObject["computed"].ToString()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var parameterOverrideValueSet = new CDP4Common.DTO.ParameterOverrideValueSet(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("computed"u8, out var computedProperty)) { - parameterOverrideValueSet.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + parameterOverrideValueSet.Computed = SerializerHelper.ToValueArray(computedProperty.GetString()); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterOverrideValueSet.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterOverrideValueSet.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["formula"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterOverrideValueSet.Formula = SerializerHelper.ToValueArray(jObject["formula"].ToString()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterOverrideValueSet.ExcludedPerson.Add(element.GetGuid()); + } } - - if (!jObject["manual"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("formula"u8, out var formulaProperty)) { - parameterOverrideValueSet.Manual = SerializerHelper.ToValueArray(jObject["manual"].ToString()); + parameterOverrideValueSet.Formula = SerializerHelper.ToValueArray(formulaProperty.GetString()); } - - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("manual"u8, out var manualProperty)) { - parameterOverrideValueSet.ModifiedOn = jObject["modifiedOn"].ToObject(); + parameterOverrideValueSet.Manual = SerializerHelper.ToValueArray(manualProperty.GetString()); } - if (!jObject["parameterValueSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterOverrideValueSet.ParameterValueSet = jObject["parameterValueSet"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + } + else + { + parameterOverrideValueSet.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["published"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValueSet"u8, out var parameterValueSetProperty)) { - parameterOverrideValueSet.Published = SerializerHelper.ToValueArray(jObject["published"].ToString()); + if(parameterValueSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterValueSet property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + } + else + { + parameterOverrideValueSet.ParameterValueSet = parameterValueSetProperty.GetGuid(); + } } - - if (!jObject["reference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("published"u8, out var publishedProperty)) + { + parameterOverrideValueSet.Published = SerializerHelper.ToValueArray(publishedProperty.GetString()); + } + if (jsonElement.TryGetProperty("reference"u8, out var referenceProperty)) { - parameterOverrideValueSet.Reference = SerializerHelper.ToValueArray(jObject["reference"].ToString()); + parameterOverrideValueSet.Reference = SerializerHelper.ToValueArray(referenceProperty.GetString()); } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterOverrideValueSet.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + } + else + { + parameterOverrideValueSet.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSwitch"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSwitch"u8, out var valueSwitchProperty)) { - parameterOverrideValueSet.ValueSwitch = jObject["valueSwitch"].ToObject(); + if(valueSwitchProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale valueSwitch property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + } + else + { + parameterOverrideValueSet.ValueSwitch = ParameterSwitchKindDeserializer.Deserialize(valueSwitchProperty); + } } return parameterOverrideValueSet; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs index 124d4eaa6..f122ceab5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,203 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Parameter FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameter = new CDP4Common.DTO.Parameter(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameter.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["allowDifferentOwnerOfOverride"].IsNullOrEmpty()) + var parameter = new CDP4Common.DTO.Parameter(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("allowDifferentOwnerOfOverride"u8, out var allowDifferentOwnerOfOverrideProperty)) { - parameter.AllowDifferentOwnerOfOverride = jObject["allowDifferentOwnerOfOverride"].ToObject(); + if(allowDifferentOwnerOfOverrideProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale allowDifferentOwnerOfOverride property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.AllowDifferentOwnerOfOverride = allowDifferentOwnerOfOverrideProperty.GetBoolean(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameter.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameter.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameter.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameter.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["expectsOverride"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("expectsOverride"u8, out var expectsOverrideProperty)) { - parameter.ExpectsOverride = jObject["expectsOverride"].ToObject(); + if(expectsOverrideProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale expectsOverride property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.ExpectsOverride = expectsOverrideProperty.GetBoolean(); + } } - if (!jObject["group"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("group"u8, out var groupProperty)) { - parameter.Group = jObject["group"].ToObject(); + if(groupProperty.ValueKind == JsonValueKind.Null) + { + parameter.Group = null; + } + else + { + parameter.Group = groupProperty.GetGuid(); + } } - if (!jObject["isOptionDependent"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isOptionDependent"u8, out var isOptionDependentProperty)) { - parameter.IsOptionDependent = jObject["isOptionDependent"].ToObject(); + if(isOptionDependentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isOptionDependent property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.IsOptionDependent = isOptionDependentProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameter.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - parameter.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterSubscription"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterSubscription"u8, out var parameterSubscriptionProperty) && parameterSubscriptionProperty.ValueKind != JsonValueKind.Null) { - parameter.ParameterSubscription.AddRange(jObject["parameterSubscription"].ToObject>()); + foreach(var element in parameterSubscriptionProperty.EnumerateArray()) + { + parameter.ParameterSubscription.Add(element.GetGuid()); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - parameter.ParameterType = jObject["parameterType"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["requestedBy"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requestedBy"u8, out var requestedByProperty)) { - parameter.RequestedBy = jObject["requestedBy"].ToObject(); + if(requestedByProperty.ValueKind == JsonValueKind.Null) + { + parameter.RequestedBy = null; + } + else + { + parameter.RequestedBy = requestedByProperty.GetGuid(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - parameter.Scale = jObject["scale"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + parameter.Scale = null; + } + else + { + parameter.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["stateDependence"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stateDependence"u8, out var stateDependenceProperty)) { - parameter.StateDependence = jObject["stateDependence"].ToObject(); + if(stateDependenceProperty.ValueKind == JsonValueKind.Null) + { + parameter.StateDependence = null; + } + else + { + parameter.StateDependence = stateDependenceProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameter.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameter {id} is null", parameter.Iid); + } + else + { + parameter.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSet"u8, out var valueSetProperty) && valueSetProperty.ValueKind != JsonValueKind.Null) { - parameter.ValueSet.AddRange(jObject["valueSet"].ToObject>()); + foreach(var element in valueSetProperty.EnumerateArray()) + { + parameter.ValueSet.Add(element.GetGuid()); + } } return parameter; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs index eced250bd..98f8d7966 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,99 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterSubscriptionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterSubscription FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterSubscription FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterSubscription = new CDP4Common.DTO.ParameterSubscription(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterSubscriptionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterSubscription.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var parameterSubscription = new CDP4Common.DTO.ParameterSubscription(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterSubscription.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterSubscription.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterSubscription.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterSubscription.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterSubscription.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterSubscription {id} is null", parameterSubscription.Iid); + } + else + { + parameterSubscription.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - parameterSubscription.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the parameterSubscription {id} is null", parameterSubscription.Iid); + } + else + { + parameterSubscription.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterSubscription.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterSubscription {id} is null", parameterSubscription.Iid); + } + else + { + parameterSubscription.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSet"u8, out var valueSetProperty) && valueSetProperty.ValueKind != JsonValueKind.Null) { - parameterSubscription.ValueSet.AddRange(jObject["valueSet"].ToObject>()); + foreach(var element in valueSetProperty.EnumerateArray()) + { + parameterSubscription.ValueSet.Add(element.GetGuid()); + } } return parameterSubscription; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs index f7e18d00d..e96359edd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,107 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterSubscriptionValueSetResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterSubscriptionValueSet = new CDP4Common.DTO.ParameterSubscriptionValueSet(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - parameterSubscriptionValueSet.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the ParameterSubscriptionValueSetResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterSubscriptionValueSet.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var parameterSubscriptionValueSet = new CDP4Common.DTO.ParameterSubscriptionValueSet(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterSubscriptionValueSet.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterSubscriptionValueSet.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["manual"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) + { + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterSubscriptionValueSet.ExcludedPerson.Add(element.GetGuid()); + } + } + if (jsonElement.TryGetProperty("manual"u8, out var manualProperty)) { - parameterSubscriptionValueSet.Manual = SerializerHelper.ToValueArray(jObject["manual"].ToString()); + parameterSubscriptionValueSet.Manual = SerializerHelper.ToValueArray(manualProperty.GetString()); } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterSubscriptionValueSet.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + } + else + { + parameterSubscriptionValueSet.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["subscribedValueSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("subscribedValueSet"u8, out var subscribedValueSetProperty)) { - parameterSubscriptionValueSet.SubscribedValueSet = jObject["subscribedValueSet"].ToObject(); + if(subscribedValueSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale subscribedValueSet property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + } + else + { + parameterSubscriptionValueSet.SubscribedValueSet = subscribedValueSetProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterSubscriptionValueSet.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + } + else + { + parameterSubscriptionValueSet.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSwitch"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSwitch"u8, out var valueSwitchProperty)) { - parameterSubscriptionValueSet.ValueSwitch = jObject["valueSwitch"].ToObject(); + if(valueSwitchProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale valueSwitch property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + } + else + { + parameterSubscriptionValueSet.ValueSwitch = ParameterSwitchKindDeserializer.Deserialize(valueSwitchProperty); + } } return parameterSubscriptionValueSet; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs index 6dbd6614b..46dd2f162 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterTypeComponentResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterTypeComponent = new CDP4Common.DTO.ParameterTypeComponent(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterTypeComponentResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterTypeComponent.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var parameterTypeComponent = new CDP4Common.DTO.ParameterTypeComponent(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterTypeComponent.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterTypeComponent.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterTypeComponent.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterTypeComponent.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterTypeComponent.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + } + else + { + parameterTypeComponent.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - parameterTypeComponent.ParameterType = jObject["parameterType"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + } + else + { + parameterTypeComponent.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - parameterTypeComponent.Scale = jObject["scale"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + parameterTypeComponent.Scale = null; + } + else + { + parameterTypeComponent.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - parameterTypeComponent.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + } + else + { + parameterTypeComponent.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterTypeComponent.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + } + else + { + parameterTypeComponent.ThingPreference = thingPreferenceProperty.GetString(); + } } return parameterTypeComponent; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs index 9a7cc5016..c90526ee6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,135 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterValueSetResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterValueSet FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterValueSet = new CDP4Common.DTO.ParameterValueSet(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterValueSet FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - parameterValueSet.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the ParameterValueSetResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["actualOption"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterValueSet.ActualOption = jObject["actualOption"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actualState"].IsNullOrEmpty()) + var parameterValueSet = new CDP4Common.DTO.ParameterValueSet(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("actualOption"u8, out var actualOptionProperty)) { - parameterValueSet.ActualState = jObject["actualState"].ToObject(); + if(actualOptionProperty.ValueKind == JsonValueKind.Null) + { + parameterValueSet.ActualOption = null; + } + else + { + parameterValueSet.ActualOption = actualOptionProperty.GetGuid(); + } } - if (!jObject["computed"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("actualState"u8, out var actualStateProperty)) { - parameterValueSet.Computed = SerializerHelper.ToValueArray(jObject["computed"].ToString()); + if(actualStateProperty.ValueKind == JsonValueKind.Null) + { + parameterValueSet.ActualState = null; + } + else + { + parameterValueSet.ActualState = actualStateProperty.GetGuid(); + } } - - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("computed"u8, out var computedProperty)) { - parameterValueSet.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + parameterValueSet.Computed = SerializerHelper.ToValueArray(computedProperty.GetString()); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterValueSet.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterValueSet.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["formula"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterValueSet.Formula = SerializerHelper.ToValueArray(jObject["formula"].ToString()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterValueSet.ExcludedPerson.Add(element.GetGuid()); + } } - - if (!jObject["manual"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("formula"u8, out var formulaProperty)) { - parameterValueSet.Manual = SerializerHelper.ToValueArray(jObject["manual"].ToString()); + parameterValueSet.Formula = SerializerHelper.ToValueArray(formulaProperty.GetString()); } - - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("manual"u8, out var manualProperty)) { - parameterValueSet.ModifiedOn = jObject["modifiedOn"].ToObject(); + parameterValueSet.Manual = SerializerHelper.ToValueArray(manualProperty.GetString()); } - if (!jObject["published"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterValueSet.Published = SerializerHelper.ToValueArray(jObject["published"].ToString()); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterValueSet {id} is null", parameterValueSet.Iid); + } + else + { + parameterValueSet.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - - if (!jObject["reference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("published"u8, out var publishedProperty)) + { + parameterValueSet.Published = SerializerHelper.ToValueArray(publishedProperty.GetString()); + } + if (jsonElement.TryGetProperty("reference"u8, out var referenceProperty)) { - parameterValueSet.Reference = SerializerHelper.ToValueArray(jObject["reference"].ToString()); + parameterValueSet.Reference = SerializerHelper.ToValueArray(referenceProperty.GetString()); } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterValueSet.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterValueSet {id} is null", parameterValueSet.Iid); + } + else + { + parameterValueSet.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueSwitch"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueSwitch"u8, out var valueSwitchProperty)) { - parameterValueSet.ValueSwitch = jObject["valueSwitch"].ToObject(); + if(valueSwitchProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale valueSwitch property of the parameterValueSet {id} is null", parameterValueSet.Iid); + } + else + { + parameterValueSet.ValueSwitch = ParameterSwitchKindDeserializer.Deserialize(valueSwitchProperty); + } } return parameterValueSet; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs index fdb38aa5b..8e2827fdf 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParameterizedCategoryRuleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parameterizedCategoryRule = new CDP4Common.DTO.ParameterizedCategoryRule(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParameterizedCategoryRuleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parameterizedCategoryRule.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var parameterizedCategoryRule = new CDP4Common.DTO.ParameterizedCategoryRule(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + parameterizedCategoryRule.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty)) { - parameterizedCategoryRule.Category = jObject["category"].ToObject(); + if(categoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale category property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.Category = categoryProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + parameterizedCategoryRule.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parameterizedCategoryRule.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parameterizedCategoryRule.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + parameterizedCategoryRule.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - parameterizedCategoryRule.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parameterizedCategoryRule.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - parameterizedCategoryRule.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.Name = nameProperty.GetString(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty) && parameterTypeProperty.ValueKind != JsonValueKind.Null) { - parameterizedCategoryRule.ParameterType.AddRange(jObject["parameterType"].ToObject>()); + foreach(var element in parameterTypeProperty.EnumerateArray()) + { + parameterizedCategoryRule.ParameterType.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - parameterizedCategoryRule.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parameterizedCategoryRule.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + } + else + { + parameterizedCategoryRule.ThingPreference = thingPreferenceProperty.GetString(); + } } return parameterizedCategoryRule; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs index 46f4fea29..f2d354a87 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,99 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParametricConstraintResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParametricConstraint FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParametricConstraint FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var parametricConstraint = new CDP4Common.DTO.ParametricConstraint(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParametricConstraintResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - parametricConstraint.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var parametricConstraint = new CDP4Common.DTO.ParametricConstraint(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - parametricConstraint.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + parametricConstraint.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - parametricConstraint.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + parametricConstraint.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["expression"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("expression"u8, out var expressionProperty) && expressionProperty.ValueKind != JsonValueKind.Null) { - parametricConstraint.Expression.AddRange(jObject["expression"].ToObject>()); + foreach(var element in expressionProperty.EnumerateArray()) + { + parametricConstraint.Expression.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - parametricConstraint.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the parametricConstraint {id} is null", parametricConstraint.Iid); + } + else + { + parametricConstraint.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - parametricConstraint.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the parametricConstraint {id} is null", parametricConstraint.Iid); + } + else + { + parametricConstraint.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["topExpression"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("topExpression"u8, out var topExpressionProperty)) { - parametricConstraint.TopExpression = jObject["topExpression"].ToObject(); + if(topExpressionProperty.ValueKind == JsonValueKind.Null) + { + parametricConstraint.TopExpression = null; + } + else + { + parametricConstraint.TopExpression = topExpressionProperty.GetGuid(); + } } return parametricConstraint; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs index 217214995..fb6c00c08 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParticipantPermissionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var participantPermission = new CDP4Common.DTO.ParticipantPermission(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParticipantPermissionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["accessRight"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - participantPermission.AccessRight = jObject["accessRight"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actor"].IsNullOrEmpty()) + var participantPermission = new CDP4Common.DTO.ParticipantPermission(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("accessRight"u8, out var accessRightProperty)) { - participantPermission.Actor = jObject["actor"].ToObject(); + if(accessRightProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale accessRight property of the participantPermission {id} is null", participantPermission.Iid); + } + else + { + participantPermission.AccessRight = ParticipantAccessRightKindDeserializer.Deserialize(accessRightProperty); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - participantPermission.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + participantPermission.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - participantPermission.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + participantPermission.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - participantPermission.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the participantPermission {id} is null", participantPermission.Iid); + } + else + { + participantPermission.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - participantPermission.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the participantPermission {id} is null", participantPermission.Iid); + } + else + { + participantPermission.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["objectClass"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("objectClass"u8, out var objectClassProperty)) { - participantPermission.ObjectClass = jObject["objectClass"].ToObject(); + if(objectClassProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale objectClass property of the participantPermission {id} is null", participantPermission.Iid); + } + else + { + participantPermission.ObjectClass = ClassKindDeserializer.Deserialize(objectClassProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - participantPermission.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the participantPermission {id} is null", participantPermission.Iid); + } + else + { + participantPermission.ThingPreference = thingPreferenceProperty.GetString(); + } } return participantPermission; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs index c679f694c..0748cf6a6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,135 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParticipantResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Participant FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var participant = new CDP4Common.DTO.Participant(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParticipantResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - participant.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["domain"].IsNullOrEmpty()) + var participant = new CDP4Common.DTO.Participant(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("domain"u8, out var domainProperty) && domainProperty.ValueKind != JsonValueKind.Null) { - participant.Domain.AddRange(jObject["domain"].ToObject>()); + foreach(var element in domainProperty.EnumerateArray()) + { + participant.Domain.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - participant.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + participant.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - participant.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + participant.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isActive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isActive"u8, out var isActiveProperty)) { - participant.IsActive = jObject["isActive"].ToObject(); + if(isActiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isActive property of the participant {id} is null", participant.Iid); + } + else + { + participant.IsActive = isActiveProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - participant.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the participant {id} is null", participant.Iid); + } + else + { + participant.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["person"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("person"u8, out var personProperty)) { - participant.Person = jObject["person"].ToObject(); + if(personProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale person property of the participant {id} is null", participant.Iid); + } + else + { + participant.Person = personProperty.GetGuid(); + } } - if (!jObject["role"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("role"u8, out var roleProperty)) { - participant.Role = jObject["role"].ToObject(); + if(roleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale role property of the participant {id} is null", participant.Iid); + } + else + { + participant.Role = roleProperty.GetGuid(); + } } - if (!jObject["selectedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("selectedDomain"u8, out var selectedDomainProperty)) { - participant.SelectedDomain = jObject["selectedDomain"].ToObject(); + if(selectedDomainProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale selectedDomain property of the participant {id} is null", participant.Iid); + } + else + { + participant.SelectedDomain = selectedDomainProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - participant.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the participant {id} is null", participant.Iid); + } + else + { + participant.ThingPreference = thingPreferenceProperty.GetString(); + } } return participant; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs index d0ee24c56..d9f821a41 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,147 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ParticipantRoleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ParticipantRole FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var participantRole = new CDP4Common.DTO.ParticipantRole(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ParticipantRoleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - participantRole.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var participantRole = new CDP4Common.DTO.ParticipantRole(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - participantRole.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + participantRole.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - participantRole.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + participantRole.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - participantRole.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + participantRole.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - participantRole.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + participantRole.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - participantRole.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + participantRole.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - participantRole.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the participantRole {id} is null", participantRole.Iid); + } + else + { + participantRole.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - participantRole.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the participantRole {id} is null", participantRole.Iid); + } + else + { + participantRole.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - participantRole.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the participantRole {id} is null", participantRole.Iid); + } + else + { + participantRole.Name = nameProperty.GetString(); + } } - if (!jObject["participantPermission"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("participantPermission"u8, out var participantPermissionProperty) && participantPermissionProperty.ValueKind != JsonValueKind.Null) { - participantRole.ParticipantPermission.AddRange(jObject["participantPermission"].ToObject>()); + foreach(var element in participantPermissionProperty.EnumerateArray()) + { + participantRole.ParticipantPermission.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - participantRole.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the participantRole {id} is null", participantRole.Iid); + } + else + { + participantRole.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - participantRole.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the participantRole {id} is null", participantRole.Iid); + } + else + { + participantRole.ThingPreference = thingPreferenceProperty.GetString(); + } } return participantRole; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs index 09be84327..e9bf0582a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PersonPermissionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.PersonPermission FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var personPermission = new CDP4Common.DTO.PersonPermission(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PersonPermissionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["accessRight"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - personPermission.AccessRight = jObject["accessRight"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["actor"].IsNullOrEmpty()) + var personPermission = new CDP4Common.DTO.PersonPermission(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("accessRight"u8, out var accessRightProperty)) { - personPermission.Actor = jObject["actor"].ToObject(); + if(accessRightProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale accessRight property of the personPermission {id} is null", personPermission.Iid); + } + else + { + personPermission.AccessRight = PersonAccessRightKindDeserializer.Deserialize(accessRightProperty); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - personPermission.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + personPermission.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - personPermission.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + personPermission.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - personPermission.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the personPermission {id} is null", personPermission.Iid); + } + else + { + personPermission.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - personPermission.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the personPermission {id} is null", personPermission.Iid); + } + else + { + personPermission.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["objectClass"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("objectClass"u8, out var objectClassProperty)) { - personPermission.ObjectClass = jObject["objectClass"].ToObject(); + if(objectClassProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale objectClass property of the personPermission {id} is null", personPermission.Iid); + } + else + { + personPermission.ObjectClass = ClassKindDeserializer.Deserialize(objectClassProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - personPermission.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the personPermission {id} is null", personPermission.Iid); + } + else + { + personPermission.ThingPreference = thingPreferenceProperty.GetString(); + } } return personPermission; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs index b2e10cf76..e5c3c1b4b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,131 +28,247 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PersonResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Person FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var person = new CDP4Common.DTO.Person(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PersonResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - person.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["defaultDomain"].IsNullOrEmpty()) + var person = new CDP4Common.DTO.Person(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("defaultDomain"u8, out var defaultDomainProperty)) { - person.DefaultDomain = jObject["defaultDomain"].ToObject(); + if(defaultDomainProperty.ValueKind == JsonValueKind.Null) + { + person.DefaultDomain = null; + } + else + { + person.DefaultDomain = defaultDomainProperty.GetGuid(); + } } - if (!jObject["defaultEmailAddress"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultEmailAddress"u8, out var defaultEmailAddressProperty)) { - person.DefaultEmailAddress = jObject["defaultEmailAddress"].ToObject(); + if(defaultEmailAddressProperty.ValueKind == JsonValueKind.Null) + { + person.DefaultEmailAddress = null; + } + else + { + person.DefaultEmailAddress = defaultEmailAddressProperty.GetGuid(); + } } - if (!jObject["defaultTelephoneNumber"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultTelephoneNumber"u8, out var defaultTelephoneNumberProperty)) { - person.DefaultTelephoneNumber = jObject["defaultTelephoneNumber"].ToObject(); + if(defaultTelephoneNumberProperty.ValueKind == JsonValueKind.Null) + { + person.DefaultTelephoneNumber = null; + } + else + { + person.DefaultTelephoneNumber = defaultTelephoneNumberProperty.GetGuid(); + } } - if (!jObject["emailAddress"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("emailAddress"u8, out var emailAddressProperty) && emailAddressProperty.ValueKind != JsonValueKind.Null) { - person.EmailAddress.AddRange(jObject["emailAddress"].ToObject>()); + foreach(var element in emailAddressProperty.EnumerateArray()) + { + person.EmailAddress.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - person.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + person.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - person.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + person.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["givenName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("givenName"u8, out var givenNameProperty)) { - person.GivenName = jObject["givenName"].ToObject(); + if(givenNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale givenName property of the person {id} is null", person.Iid); + } + else + { + person.GivenName = givenNameProperty.GetString(); + } } - if (!jObject["isActive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isActive"u8, out var isActiveProperty)) { - person.IsActive = jObject["isActive"].ToObject(); + if(isActiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isActive property of the person {id} is null", person.Iid); + } + else + { + person.IsActive = isActiveProperty.GetBoolean(); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - person.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the person {id} is null", person.Iid); + } + else + { + person.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - person.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the person {id} is null", person.Iid); + } + else + { + person.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["organization"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organization"u8, out var organizationProperty)) { - person.Organization = jObject["organization"].ToObject(); + if(organizationProperty.ValueKind == JsonValueKind.Null) + { + person.Organization = null; + } + else + { + person.Organization = organizationProperty.GetGuid(); + } } - if (!jObject["organizationalUnit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organizationalUnit"u8, out var organizationalUnitProperty)) { - person.OrganizationalUnit = jObject["organizationalUnit"].ToObject(); + if(organizationalUnitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale organizationalUnit property of the person {id} is null", person.Iid); + } + else + { + person.OrganizationalUnit = organizationalUnitProperty.GetString(); + } } - if (!jObject["password"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("password"u8, out var passwordProperty)) { - person.Password = jObject["password"].ToObject(); + if(passwordProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale password property of the person {id} is null", person.Iid); + } + else + { + person.Password = passwordProperty.GetString(); + } } - if (!jObject["role"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("role"u8, out var roleProperty)) { - person.Role = jObject["role"].ToObject(); + if(roleProperty.ValueKind == JsonValueKind.Null) + { + person.Role = null; + } + else + { + person.Role = roleProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - person.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the person {id} is null", person.Iid); + } + else + { + person.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["surname"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("surname"u8, out var surnameProperty)) { - person.Surname = jObject["surname"].ToObject(); + if(surnameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale surname property of the person {id} is null", person.Iid); + } + else + { + person.Surname = surnameProperty.GetString(); + } } - if (!jObject["telephoneNumber"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("telephoneNumber"u8, out var telephoneNumberProperty) && telephoneNumberProperty.ValueKind != JsonValueKind.Null) { - person.TelephoneNumber.AddRange(jObject["telephoneNumber"].ToObject>()); + foreach(var element in telephoneNumberProperty.EnumerateArray()) + { + person.TelephoneNumber.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - person.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the person {id} is null", person.Iid); + } + else + { + person.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["userPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("userPreference"u8, out var userPreferenceProperty) && userPreferenceProperty.ValueKind != JsonValueKind.Null) { - person.UserPreference.AddRange(jObject["userPreference"].ToObject>()); + foreach(var element in userPreferenceProperty.EnumerateArray()) + { + person.UserPreference.Add(element.GetGuid()); + } } return person; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs index ba1463cb2..0b6afb333 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,147 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PersonRoleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.PersonRole FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var personRole = new CDP4Common.DTO.PersonRole(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PersonRoleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - personRole.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var personRole = new CDP4Common.DTO.PersonRole(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - personRole.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + personRole.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - personRole.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + personRole.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - personRole.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + personRole.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - personRole.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + personRole.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - personRole.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + personRole.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - personRole.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the personRole {id} is null", personRole.Iid); + } + else + { + personRole.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - personRole.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the personRole {id} is null", personRole.Iid); + } + else + { + personRole.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - personRole.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the personRole {id} is null", personRole.Iid); + } + else + { + personRole.Name = nameProperty.GetString(); + } } - if (!jObject["personPermission"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("personPermission"u8, out var personPermissionProperty) && personPermissionProperty.ValueKind != JsonValueKind.Null) { - personRole.PersonPermission.AddRange(jObject["personPermission"].ToObject>()); + foreach(var element in personPermissionProperty.EnumerateArray()) + { + personRole.PersonPermission.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - personRole.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the personRole {id} is null", personRole.Iid); + } + else + { + personRole.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - personRole.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the personRole {id} is null", personRole.Iid); + } + else + { + personRole.ThingPreference = thingPreferenceProperty.GetString(); + } } return personRole; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs index 181107f48..fb36ae541 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PointResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Point FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var point = new CDP4Common.DTO.Point(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PointResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - point.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var point = new CDP4Common.DTO.Point(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - point.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + point.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - point.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + point.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - point.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the point {id} is null", point.Iid); + } + else + { + point.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - point.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the point {id} is null", point.Iid); + } + else + { + point.Name = nameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - point.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the point {id} is null", point.Iid); + } + else + { + point.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["x"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("x"u8, out var xProperty)) { - point.X = jObject["x"].ToObject(); + if(xProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale x property of the point {id} is null", point.Iid); + } + else + { + point.X = xProperty.GetSingle(); + } } - if (!jObject["y"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("y"u8, out var yProperty)) { - point.Y = jObject["y"].ToObject(); + if(yProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale y property of the point {id} is null", point.Iid); + } + else + { + point.Y = yProperty.GetSingle(); + } } return point; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs index a98be4967..3f9da6d33 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,164 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PossibleFiniteStateListResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var possibleFiniteStateList = new CDP4Common.DTO.PossibleFiniteStateList(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PossibleFiniteStateListResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - possibleFiniteStateList.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var possibleFiniteStateList = new CDP4Common.DTO.PossibleFiniteStateList(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + possibleFiniteStateList.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + possibleFiniteStateList.Category.Add(element.GetGuid()); + } } - if (!jObject["defaultState"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultState"u8, out var defaultStateProperty)) { - possibleFiniteStateList.DefaultState = jObject["defaultState"].ToObject(); + if(defaultStateProperty.ValueKind == JsonValueKind.Null) + { + possibleFiniteStateList.DefaultState = null; + } + else + { + possibleFiniteStateList.DefaultState = defaultStateProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + possibleFiniteStateList.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + possibleFiniteStateList.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + possibleFiniteStateList.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteStateList.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + possibleFiniteStateList.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - possibleFiniteStateList.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + } + else + { + possibleFiniteStateList.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - possibleFiniteStateList.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + } + else + { + possibleFiniteStateList.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - possibleFiniteStateList.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + } + else + { + possibleFiniteStateList.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["possibleState"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleState"u8, out var possibleStateProperty)) { - possibleFiniteStateList.PossibleState.AddRange(jObject["possibleState"].ToOrderedItemCollection()); + possibleFiniteStateList.PossibleState.AddRange(possibleStateProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - possibleFiniteStateList.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + } + else + { + possibleFiniteStateList.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - possibleFiniteStateList.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + } + else + { + possibleFiniteStateList.ThingPreference = thingPreferenceProperty.GetString(); + } } return possibleFiniteStateList; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs index e0a389897..03d5087d8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PossibleFiniteStateResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var possibleFiniteState = new CDP4Common.DTO.PossibleFiniteState(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PossibleFiniteStateResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - possibleFiniteState.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var possibleFiniteState = new CDP4Common.DTO.PossibleFiniteState(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteState.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + possibleFiniteState.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteState.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + possibleFiniteState.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteState.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + possibleFiniteState.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteState.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + possibleFiniteState.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - possibleFiniteState.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + possibleFiniteState.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - possibleFiniteState.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + } + else + { + possibleFiniteState.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - possibleFiniteState.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + } + else + { + possibleFiniteState.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - possibleFiniteState.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + } + else + { + possibleFiniteState.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - possibleFiniteState.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + } + else + { + possibleFiniteState.ThingPreference = thingPreferenceProperty.GetString(); + } } return possibleFiniteState; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs index 169c75fc7..e5864560b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PrefixedUnitResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var prefixedUnit = new CDP4Common.DTO.PrefixedUnit(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PrefixedUnitResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - prefixedUnit.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var prefixedUnit = new CDP4Common.DTO.PrefixedUnit(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - prefixedUnit.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + prefixedUnit.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - prefixedUnit.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + prefixedUnit.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - prefixedUnit.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + prefixedUnit.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - prefixedUnit.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + prefixedUnit.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - prefixedUnit.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + prefixedUnit.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - prefixedUnit.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the prefixedUnit {id} is null", prefixedUnit.Iid); + } + else + { + prefixedUnit.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - prefixedUnit.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the prefixedUnit {id} is null", prefixedUnit.Iid); + } + else + { + prefixedUnit.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["prefix"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("prefix"u8, out var prefixProperty)) { - prefixedUnit.Prefix = jObject["prefix"].ToObject(); + if(prefixProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale prefix property of the prefixedUnit {id} is null", prefixedUnit.Iid); + } + else + { + prefixedUnit.Prefix = prefixProperty.GetGuid(); + } } - if (!jObject["referenceUnit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceUnit"u8, out var referenceUnitProperty)) { - prefixedUnit.ReferenceUnit = jObject["referenceUnit"].ToObject(); + if(referenceUnitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referenceUnit property of the prefixedUnit {id} is null", prefixedUnit.Iid); + } + else + { + prefixedUnit.ReferenceUnit = referenceUnitProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - prefixedUnit.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the prefixedUnit {id} is null", prefixedUnit.Iid); + } + else + { + prefixedUnit.ThingPreference = thingPreferenceProperty.GetString(); + } } return prefixedUnit; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs index e583d5355..8928ca912 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,107 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class PublicationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Publication FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Publication FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var publication = new CDP4Common.DTO.Publication(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the PublicationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - publication.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["createdOn"].IsNullOrEmpty()) + var publication = new CDP4Common.DTO.Publication(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - publication.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the publication {id} is null", publication.Iid); + } + else + { + publication.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["domain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("domain"u8, out var domainProperty) && domainProperty.ValueKind != JsonValueKind.Null) { - publication.Domain.AddRange(jObject["domain"].ToObject>()); + foreach(var element in domainProperty.EnumerateArray()) + { + publication.Domain.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - publication.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + publication.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - publication.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + publication.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - publication.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the publication {id} is null", publication.Iid); + } + else + { + publication.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["publishedParameter"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("publishedParameter"u8, out var publishedParameterProperty) && publishedParameterProperty.ValueKind != JsonValueKind.Null) { - publication.PublishedParameter.AddRange(jObject["publishedParameter"].ToObject>()); + foreach(var element in publishedParameterProperty.EnumerateArray()) + { + publication.PublishedParameter.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - publication.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the publication {id} is null", publication.Iid); + } + else + { + publication.ThingPreference = thingPreferenceProperty.GetString(); + } } return publication; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs index 83a1d1442..ce4a93914 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class QuantityKindFactorResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var quantityKindFactor = new CDP4Common.DTO.QuantityKindFactor(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the QuantityKindFactorResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - quantityKindFactor.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var quantityKindFactor = new CDP4Common.DTO.QuantityKindFactor(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - quantityKindFactor.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + quantityKindFactor.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - quantityKindFactor.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + quantityKindFactor.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["exponent"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("exponent"u8, out var exponentProperty)) { - quantityKindFactor.Exponent = jObject["exponent"].ToObject(); + if(exponentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale exponent property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + } + else + { + quantityKindFactor.Exponent = exponentProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - quantityKindFactor.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + } + else + { + quantityKindFactor.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["quantityKind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("quantityKind"u8, out var quantityKindProperty)) { - quantityKindFactor.QuantityKind = jObject["quantityKind"].ToObject(); + if(quantityKindProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale quantityKind property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + } + else + { + quantityKindFactor.QuantityKind = quantityKindProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - quantityKindFactor.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + } + else + { + quantityKindFactor.ThingPreference = thingPreferenceProperty.GetString(); + } } return quantityKindFactor; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs index 4769b83b3..3f4d494dc 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,136 +28,251 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RatioScaleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RatioScale FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var ratioScale = new CDP4Common.DTO.RatioScale(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RatioScaleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - ratioScale.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var ratioScale = new CDP4Common.DTO.RatioScale(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - ratioScale.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + ratioScale.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - ratioScale.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + ratioScale.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - ratioScale.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + ratioScale.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - ratioScale.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + ratioScale.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - ratioScale.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + ratioScale.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - ratioScale.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["isMaximumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMaximumInclusive"u8, out var isMaximumInclusiveProperty)) { - ratioScale.IsMaximumInclusive = jObject["isMaximumInclusive"].ToObject(); + if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMaximumInclusive property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.IsMaximumInclusive = isMaximumInclusiveProperty.GetBoolean(); + } } - if (!jObject["isMinimumInclusive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isMinimumInclusive"u8, out var isMinimumInclusiveProperty)) { - ratioScale.IsMinimumInclusive = jObject["isMinimumInclusive"].ToObject(); + if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isMinimumInclusive property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.IsMinimumInclusive = isMinimumInclusiveProperty.GetBoolean(); + } } - if (!jObject["mappingToReferenceScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("mappingToReferenceScale"u8, out var mappingToReferenceScaleProperty) && mappingToReferenceScaleProperty.ValueKind != JsonValueKind.Null) { - ratioScale.MappingToReferenceScale.AddRange(jObject["mappingToReferenceScale"].ToObject>()); + foreach(var element in mappingToReferenceScaleProperty.EnumerateArray()) + { + ratioScale.MappingToReferenceScale.Add(element.GetGuid()); + } } - if (!jObject["maximumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maximumPermissibleValue"u8, out var maximumPermissibleValueProperty)) { - ratioScale.MaximumPermissibleValue = jObject["maximumPermissibleValue"].ToObject(); + if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maximumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.MaximumPermissibleValue = maximumPermissibleValueProperty.GetString(); + } } - if (!jObject["minimumPermissibleValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minimumPermissibleValue"u8, out var minimumPermissibleValueProperty)) { - ratioScale.MinimumPermissibleValue = jObject["minimumPermissibleValue"].ToObject(); + if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minimumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.MinimumPermissibleValue = minimumPermissibleValueProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - ratioScale.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - ratioScale.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.Name = nameProperty.GetString(); + } } - if (!jObject["negativeValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("negativeValueConnotation"u8, out var negativeValueConnotationProperty)) { - ratioScale.NegativeValueConnotation = jObject["negativeValueConnotation"].ToObject(); + if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale negativeValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.NegativeValueConnotation = negativeValueConnotationProperty.GetString(); + } } - if (!jObject["numberSet"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("numberSet"u8, out var numberSetProperty)) { - ratioScale.NumberSet = jObject["numberSet"].ToObject(); + if(numberSetProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale numberSet property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.NumberSet = NumberSetKindDeserializer.Deserialize(numberSetProperty); + } } - if (!jObject["positiveValueConnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("positiveValueConnotation"u8, out var positiveValueConnotationProperty)) { - ratioScale.PositiveValueConnotation = jObject["positiveValueConnotation"].ToObject(); + if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale positiveValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.PositiveValueConnotation = positiveValueConnotationProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - ratioScale.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - ratioScale.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - ratioScale.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the ratioScale {id} is null", ratioScale.Iid); + } + else + { + ratioScale.Unit = unitProperty.GetGuid(); + } } - if (!jObject["valueDefinition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueDefinition"u8, out var valueDefinitionProperty) && valueDefinitionProperty.ValueKind != JsonValueKind.Null) { - ratioScale.ValueDefinition.AddRange(jObject["valueDefinition"].ToObject>()); + foreach(var element in valueDefinitionProperty.EnumerateArray()) + { + ratioScale.ValueDefinition.Add(element.GetGuid()); + } } return ratioScale; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs index 5288cfaed..4590d1a68 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,126 +28,231 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ReferenceSourceResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ReferenceSource FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var referenceSource = new CDP4Common.DTO.ReferenceSource(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ReferenceSourceResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - referenceSource.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var referenceSource = new CDP4Common.DTO.ReferenceSource(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - referenceSource.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + referenceSource.Alias.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - referenceSource.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.Author = authorProperty.GetString(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - referenceSource.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + referenceSource.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - referenceSource.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + referenceSource.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - referenceSource.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + referenceSource.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - referenceSource.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + referenceSource.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - referenceSource.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + referenceSource.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - referenceSource.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["language"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("language"u8, out var languageProperty)) { - referenceSource.Language = jObject["language"].ToObject(); + if(languageProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale language property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.Language = languageProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - referenceSource.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - referenceSource.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.Name = nameProperty.GetString(); + } } - if (!jObject["publicationYear"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("publicationYear"u8, out var publicationYearProperty)) { - referenceSource.PublicationYear = jObject["publicationYear"].ToObject(); + if(publicationYearProperty.ValueKind == JsonValueKind.Null) + { + referenceSource.PublicationYear = null; + } + else + { + referenceSource.PublicationYear = publicationYearProperty.GetInt32(); + } } - if (!jObject["publishedIn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("publishedIn"u8, out var publishedInProperty)) { - referenceSource.PublishedIn = jObject["publishedIn"].ToObject(); + if(publishedInProperty.ValueKind == JsonValueKind.Null) + { + referenceSource.PublishedIn = null; + } + else + { + referenceSource.PublishedIn = publishedInProperty.GetGuid(); + } } - if (!jObject["publisher"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("publisher"u8, out var publisherProperty)) { - referenceSource.Publisher = jObject["publisher"].ToObject(); + if(publisherProperty.ValueKind == JsonValueKind.Null) + { + referenceSource.Publisher = null; + } + else + { + referenceSource.Publisher = publisherProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - referenceSource.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - referenceSource.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["versionDate"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("versionDate"u8, out var versionDateProperty)) { - referenceSource.VersionDate = jObject["versionDate"].ToObject(); + if(versionDateProperty.ValueKind == JsonValueKind.Null) + { + referenceSource.VersionDate = null; + } + else + { + referenceSource.VersionDate = versionDateProperty.GetDateTime(); + } } - if (!jObject["versionIdentifier"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("versionIdentifier"u8, out var versionIdentifierProperty)) { - referenceSource.VersionIdentifier = jObject["versionIdentifier"].ToObject(); + if(versionIdentifierProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale versionIdentifier property of the referenceSource {id} is null", referenceSource.Iid); + } + else + { + referenceSource.VersionIdentifier = versionIdentifierProperty.GetString(); + } } return referenceSource; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs index 457e04d20..c965a9f79 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,106 +28,183 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ReferencerRuleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ReferencerRule FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var referencerRule = new CDP4Common.DTO.ReferencerRule(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ReferencerRuleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - referencerRule.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var referencerRule = new CDP4Common.DTO.ReferencerRule(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - referencerRule.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + referencerRule.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - referencerRule.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + referencerRule.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - referencerRule.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + referencerRule.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - referencerRule.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + referencerRule.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - referencerRule.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + referencerRule.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - referencerRule.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["maxReferenced"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("maxReferenced"u8, out var maxReferencedProperty)) { - referencerRule.MaxReferenced = jObject["maxReferenced"].ToObject(); + if(maxReferencedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale maxReferenced property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.MaxReferenced = maxReferencedProperty.GetInt32(); + } } - if (!jObject["minReferenced"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("minReferenced"u8, out var minReferencedProperty)) { - referencerRule.MinReferenced = jObject["minReferenced"].ToObject(); + if(minReferencedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale minReferenced property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.MinReferenced = minReferencedProperty.GetInt32(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - referencerRule.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - referencerRule.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.Name = nameProperty.GetString(); + } } - if (!jObject["referencedCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedCategory"u8, out var referencedCategoryProperty) && referencedCategoryProperty.ValueKind != JsonValueKind.Null) { - referencerRule.ReferencedCategory.AddRange(jObject["referencedCategory"].ToObject>()); + foreach(var element in referencedCategoryProperty.EnumerateArray()) + { + referencerRule.ReferencedCategory.Add(element.GetGuid()); + } } - if (!jObject["referencingCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencingCategory"u8, out var referencingCategoryProperty)) { - referencerRule.ReferencingCategory = jObject["referencingCategory"].ToObject(); + if(referencingCategoryProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referencingCategory property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.ReferencingCategory = referencingCategoryProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - referencerRule.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - referencerRule.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the referencerRule {id} is null", referencerRule.Iid); + } + else + { + referencerRule.ThingPreference = thingPreferenceProperty.GetString(); + } } return referencerRule; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs index 3dbc0bd33..77c392685 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,76 +28,119 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RelationalExpressionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RelationalExpression FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var relationalExpression = new CDP4Common.DTO.RelationalExpression(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RelationalExpression FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - relationalExpression.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the RelationalExpressionResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - relationalExpression.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var relationalExpression = new CDP4Common.DTO.RelationalExpression(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - relationalExpression.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + relationalExpression.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - relationalExpression.ModifiedOn = jObject["modifiedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + relationalExpression.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - relationalExpression.ParameterType = jObject["parameterType"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the relationalExpression {id} is null", relationalExpression.Iid); + } + else + { + relationalExpression.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["relationalOperator"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - relationalExpression.RelationalOperator = jObject["relationalOperator"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the relationalExpression {id} is null", relationalExpression.Iid); + } + else + { + relationalExpression.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relationalOperator"u8, out var relationalOperatorProperty)) { - relationalExpression.Scale = jObject["scale"].ToObject(); + if(relationalOperatorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale relationalOperator property of the relationalExpression {id} is null", relationalExpression.Iid); + } + else + { + relationalExpression.RelationalOperator = RelationalOperatorKindDeserializer.Deserialize(relationalOperatorProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - relationalExpression.ThingPreference = jObject["thingPreference"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + relationalExpression.Scale = null; + } + else + { + relationalExpression.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) + { + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the relationalExpression {id} is null", relationalExpression.Iid); + } + else + { + relationalExpression.ThingPreference = thingPreferenceProperty.GetString(); + } + } + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - relationalExpression.Value = SerializerHelper.ToValueArray(jObject["value"].ToString()); + relationalExpression.Value = SerializerHelper.ToValueArray(valueProperty.GetString()); } return relationalExpression; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs index 37c46402e..8437ea8ad 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,107 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RelationshipParameterValueResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RelationshipParameterValue FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var relationshipParameterValue = new CDP4Common.DTO.RelationshipParameterValue(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RelationshipParameterValue FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - relationshipParameterValue.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the RelationshipParameterValueResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - relationshipParameterValue.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var relationshipParameterValue = new CDP4Common.DTO.RelationshipParameterValue(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - relationshipParameterValue.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + relationshipParameterValue.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - relationshipParameterValue.ModifiedOn = jObject["modifiedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + relationshipParameterValue.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - relationshipParameterValue.ParameterType = jObject["parameterType"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + } + else + { + relationshipParameterValue.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - relationshipParameterValue.Scale = jObject["scale"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + } + else + { + relationshipParameterValue.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - relationshipParameterValue.ThingPreference = jObject["thingPreference"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + relationshipParameterValue.Scale = null; + } + else + { + relationshipParameterValue.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) + { + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + } + else + { + relationshipParameterValue.ThingPreference = thingPreferenceProperty.GetString(); + } + } + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - relationshipParameterValue.Value = SerializerHelper.ToValueArray(jObject["value"].ToString()); + relationshipParameterValue.Value = SerializerHelper.ToValueArray(valueProperty.GetString()); } return relationshipParameterValue; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs index 634e54c22..f4bd88419 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,131 +28,239 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequestForDeviationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requestForDeviation = new CDP4Common.DTO.RequestForDeviation(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RequestForDeviationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requestForDeviation.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var requestForDeviation = new CDP4Common.DTO.RequestForDeviation(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + requestForDeviation.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - requestForDeviation.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + requestForDeviation.Category.Add(element.GetGuid()); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - requestForDeviation.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - requestForDeviation.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - requestForDeviation.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + requestForDeviation.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requestForDeviation.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requestForDeviation.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - requestForDeviation.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requestForDeviation.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - requestForDeviation.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - requestForDeviation.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + requestForDeviation.PrimaryAnnotatedThing = null; + } + else + { + requestForDeviation.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + requestForDeviation.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - requestForDeviation.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - requestForDeviation.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + requestForDeviation.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - requestForDeviation.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - requestForDeviation.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - requestForDeviation.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the requestForDeviation {id} is null", requestForDeviation.Iid); + } + else + { + requestForDeviation.Title = titleProperty.GetString(); + } } return requestForDeviation; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs index 81baab755..e957a5040 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,131 +28,239 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequestForWaiverResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requestForWaiver = new CDP4Common.DTO.RequestForWaiver(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RequestForWaiverResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requestForWaiver.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var requestForWaiver = new CDP4Common.DTO.RequestForWaiver(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + requestForWaiver.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - requestForWaiver.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + requestForWaiver.Category.Add(element.GetGuid()); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - requestForWaiver.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - requestForWaiver.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - requestForWaiver.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + requestForWaiver.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requestForWaiver.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requestForWaiver.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - requestForWaiver.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requestForWaiver.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - requestForWaiver.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - requestForWaiver.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + requestForWaiver.PrimaryAnnotatedThing = null; + } + else + { + requestForWaiver.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + requestForWaiver.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - requestForWaiver.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - requestForWaiver.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + requestForWaiver.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - requestForWaiver.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - requestForWaiver.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - requestForWaiver.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the requestForWaiver {id} is null", requestForWaiver.Iid); + } + else + { + requestForWaiver.Title = titleProperty.GetString(); + } } return requestForWaiver; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs index 56507b5c4..5fde343c5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,184 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequirementResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Requirement FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requirement = new CDP4Common.DTO.Requirement(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RequirementResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requirement.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var requirement = new CDP4Common.DTO.Requirement(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - requirement.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + requirement.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - requirement.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + requirement.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - requirement.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + requirement.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requirement.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requirement.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requirement.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requirement.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["group"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("group"u8, out var groupProperty)) { - requirement.Group = jObject["group"].ToObject(); + if(groupProperty.ValueKind == JsonValueKind.Null) + { + requirement.Group = null; + } + else + { + requirement.Group = groupProperty.GetGuid(); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - requirement.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + requirement.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - requirement.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requirement.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - requirement.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - requirement.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValue"u8, out var parameterValueProperty) && parameterValueProperty.ValueKind != JsonValueKind.Null) { - requirement.ParameterValue.AddRange(jObject["parameterValue"].ToObject>()); + foreach(var element in parameterValueProperty.EnumerateArray()) + { + requirement.ParameterValue.Add(element.GetGuid()); + } } - if (!jObject["parametricConstraint"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parametricConstraint"u8, out var parametricConstraintProperty)) { - requirement.ParametricConstraint.AddRange(jObject["parametricConstraint"].ToOrderedItemCollection()); + requirement.ParametricConstraint.AddRange(parametricConstraintProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - requirement.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - requirement.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requirement {id} is null", requirement.Iid); + } + else + { + requirement.ThingPreference = thingPreferenceProperty.GetString(); + } } return requirement; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs index fc1aa8458..634d5fbf4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,107 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequirementsContainerParameterValueResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RequirementsContainerParameterValue FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requirementsContainerParameterValue = new CDP4Common.DTO.RequirementsContainerParameterValue(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RequirementsContainerParameterValue FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - requirementsContainerParameterValue.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the RequirementsContainerParameterValueResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requirementsContainerParameterValue.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var requirementsContainerParameterValue = new CDP4Common.DTO.RequirementsContainerParameterValue(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requirementsContainerParameterValue.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requirementsContainerParameterValue.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requirementsContainerParameterValue.ModifiedOn = jObject["modifiedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requirementsContainerParameterValue.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requirementsContainerParameterValue.ParameterType = jObject["parameterType"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + } + else + { + requirementsContainerParameterValue.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - requirementsContainerParameterValue.Scale = jObject["scale"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + } + else + { + requirementsContainerParameterValue.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - requirementsContainerParameterValue.ThingPreference = jObject["thingPreference"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + requirementsContainerParameterValue.Scale = null; + } + else + { + requirementsContainerParameterValue.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) + { + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + } + else + { + requirementsContainerParameterValue.ThingPreference = thingPreferenceProperty.GetString(); + } + } + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - requirementsContainerParameterValue.Value = SerializerHelper.ToValueArray(jObject["value"].ToString()); + requirementsContainerParameterValue.Value = SerializerHelper.ToValueArray(valueProperty.GetString()); } return requirementsContainerParameterValue; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs index acbf824eb..b6e4218e1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,163 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequirementsGroupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requirementsGroup = new CDP4Common.DTO.RequirementsGroup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RequirementsGroupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requirementsGroup.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var requirementsGroup = new CDP4Common.DTO.RequirementsGroup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + requirementsGroup.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + requirementsGroup.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + requirementsGroup.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requirementsGroup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requirementsGroup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["group"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("group"u8, out var groupProperty) && groupProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.Group.AddRange(jObject["group"].ToObject>()); + foreach(var element in groupProperty.EnumerateArray()) + { + requirementsGroup.Group.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + requirementsGroup.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requirementsGroup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requirementsGroup {id} is null", requirementsGroup.Iid); + } + else + { + requirementsGroup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - requirementsGroup.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the requirementsGroup {id} is null", requirementsGroup.Iid); + } + else + { + requirementsGroup.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - requirementsGroup.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the requirementsGroup {id} is null", requirementsGroup.Iid); + } + else + { + requirementsGroup.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValue"u8, out var parameterValueProperty) && parameterValueProperty.ValueKind != JsonValueKind.Null) { - requirementsGroup.ParameterValue.AddRange(jObject["parameterValue"].ToObject>()); + foreach(var element in parameterValueProperty.EnumerateArray()) + { + requirementsGroup.ParameterValue.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - requirementsGroup.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the requirementsGroup {id} is null", requirementsGroup.Iid); + } + else + { + requirementsGroup.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - requirementsGroup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requirementsGroup {id} is null", requirementsGroup.Iid); + } + else + { + requirementsGroup.ThingPreference = thingPreferenceProperty.GetString(); + } } return requirementsGroup; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs index 5a5b62c77..423026111 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,183 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RequirementsSpecificationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var requirementsSpecification = new CDP4Common.DTO.RequirementsSpecification(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RequirementsSpecificationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - requirementsSpecification.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var requirementsSpecification = new CDP4Common.DTO.RequirementsSpecification(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + requirementsSpecification.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + requirementsSpecification.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + requirementsSpecification.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + requirementsSpecification.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + requirementsSpecification.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["group"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("group"u8, out var groupProperty) && groupProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.Group.AddRange(jObject["group"].ToObject>()); + foreach(var element in groupProperty.EnumerateArray()) + { + requirementsSpecification.Group.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + requirementsSpecification.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - requirementsSpecification.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - requirementsSpecification.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - requirementsSpecification.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - requirementsSpecification.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["parameterValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterValue"u8, out var parameterValueProperty) && parameterValueProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.ParameterValue.AddRange(jObject["parameterValue"].ToObject>()); + foreach(var element in parameterValueProperty.EnumerateArray()) + { + requirementsSpecification.ParameterValue.Add(element.GetGuid()); + } } - if (!jObject["requirement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requirement"u8, out var requirementProperty) && requirementProperty.ValueKind != JsonValueKind.Null) { - requirementsSpecification.Requirement.AddRange(jObject["requirement"].ToObject>()); + foreach(var element in requirementProperty.EnumerateArray()) + { + requirementsSpecification.Requirement.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - requirementsSpecification.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - requirementsSpecification.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + } + else + { + requirementsSpecification.ThingPreference = thingPreferenceProperty.GetString(); + } } return requirementsSpecification; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs index 27509f2b4..ad2873076 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,136 +28,247 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ReviewItemDiscrepancyResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var reviewItemDiscrepancy = new CDP4Common.DTO.ReviewItemDiscrepancy(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ReviewItemDiscrepancyResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - reviewItemDiscrepancy.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["approvedBy"].IsNullOrEmpty()) + var reviewItemDiscrepancy = new CDP4Common.DTO.ReviewItemDiscrepancy(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("approvedBy"u8, out var approvedByProperty) && approvedByProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.ApprovedBy.AddRange(jObject["approvedBy"].ToObject>()); + foreach(var element in approvedByProperty.EnumerateArray()) + { + reviewItemDiscrepancy.ApprovedBy.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - reviewItemDiscrepancy.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + reviewItemDiscrepancy.Category.Add(element.GetGuid()); + } } - if (!jObject["classification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("classification"u8, out var classificationProperty)) { - reviewItemDiscrepancy.Classification = jObject["classification"].ToObject(); + if(classificationProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale classification property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Classification = AnnotationClassificationKindDeserializer.Deserialize(classificationProperty); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - reviewItemDiscrepancy.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - reviewItemDiscrepancy.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + reviewItemDiscrepancy.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + reviewItemDiscrepancy.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + reviewItemDiscrepancy.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - reviewItemDiscrepancy.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - reviewItemDiscrepancy.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - reviewItemDiscrepancy.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - reviewItemDiscrepancy.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + reviewItemDiscrepancy.PrimaryAnnotatedThing = null; + } + else + { + reviewItemDiscrepancy.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + reviewItemDiscrepancy.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - reviewItemDiscrepancy.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["solution"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("solution"u8, out var solutionProperty) && solutionProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.Solution.AddRange(jObject["solution"].ToObject>()); + foreach(var element in solutionProperty.EnumerateArray()) + { + reviewItemDiscrepancy.Solution.Add(element.GetGuid()); + } } - if (!jObject["sourceAnnotation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("sourceAnnotation"u8, out var sourceAnnotationProperty) && sourceAnnotationProperty.ValueKind != JsonValueKind.Null) { - reviewItemDiscrepancy.SourceAnnotation.AddRange(jObject["sourceAnnotation"].ToObject>()); + foreach(var element in sourceAnnotationProperty.EnumerateArray()) + { + reviewItemDiscrepancy.SourceAnnotation.Add(element.GetGuid()); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - reviewItemDiscrepancy.Status = jObject["status"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Status = AnnotationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - reviewItemDiscrepancy.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["title"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("title"u8, out var titleProperty)) { - reviewItemDiscrepancy.Title = jObject["title"].ToObject(); + if(titleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale title property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + } + else + { + reviewItemDiscrepancy.Title = titleProperty.GetString(); + } } return reviewItemDiscrepancy; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs index cf67bfc75..428b4121e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,144 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RuleVerificationListResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var ruleVerificationList = new CDP4Common.DTO.RuleVerificationList(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RuleVerificationListResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - ruleVerificationList.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var ruleVerificationList = new CDP4Common.DTO.RuleVerificationList(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - ruleVerificationList.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + ruleVerificationList.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - ruleVerificationList.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + ruleVerificationList.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - ruleVerificationList.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + ruleVerificationList.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - ruleVerificationList.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + ruleVerificationList.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - ruleVerificationList.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + ruleVerificationList.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - ruleVerificationList.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + } + else + { + ruleVerificationList.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - ruleVerificationList.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + } + else + { + ruleVerificationList.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - ruleVerificationList.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + } + else + { + ruleVerificationList.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["ruleVerification"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("ruleVerification"u8, out var ruleVerificationProperty)) { - ruleVerificationList.RuleVerification.AddRange(jObject["ruleVerification"].ToOrderedItemCollection()); + ruleVerificationList.RuleVerification.AddRange(ruleVerificationProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - ruleVerificationList.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + } + else + { + ruleVerificationList.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - ruleVerificationList.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + } + else + { + ruleVerificationList.ThingPreference = thingPreferenceProperty.GetString(); + } } return ruleVerificationList; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs index d2a0bf8dc..45199c0de 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,99 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class RuleViolationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.RuleViolation FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.RuleViolation FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var ruleViolation = new CDP4Common.DTO.RuleViolation(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the RuleViolationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - ruleViolation.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["description"].IsNullOrEmpty()) + var ruleViolation = new CDP4Common.DTO.RuleViolation(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("description"u8, out var descriptionProperty)) { - ruleViolation.Description = jObject["description"].ToObject(); + if(descriptionProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale description property of the ruleViolation {id} is null", ruleViolation.Iid); + } + else + { + ruleViolation.Description = descriptionProperty.GetString(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - ruleViolation.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + ruleViolation.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - ruleViolation.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + ruleViolation.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - ruleViolation.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the ruleViolation {id} is null", ruleViolation.Iid); + } + else + { + ruleViolation.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - ruleViolation.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the ruleViolation {id} is null", ruleViolation.Iid); + } + else + { + ruleViolation.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["violatingThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("violatingThing"u8, out var violatingThingProperty) && violatingThingProperty.ValueKind != JsonValueKind.Null) { - ruleViolation.ViolatingThing.AddRange(jObject["violatingThing"].ToObject>()); + foreach(var element in violatingThingProperty.EnumerateArray()) + { + ruleViolation.ViolatingThing.Add(element.GetGuid()); + } } return ruleViolation; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs index a20356d1c..c1d7c617e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,116 +28,185 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SampledFunctionParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var sampledFunctionParameterType = new CDP4Common.DTO.SampledFunctionParameterType(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - sampledFunctionParameterType.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the SampledFunctionParameterTypeResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["alias"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - sampledFunctionParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var sampledFunctionParameterType = new CDP4Common.DTO.SampledFunctionParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + sampledFunctionParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + sampledFunctionParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["degreeOfInterpolation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.DegreeOfInterpolation = jObject["degreeOfInterpolation"].ToObject(); + foreach(var element in definitionProperty.EnumerateArray()) + { + sampledFunctionParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["dependentParameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("degreeOfInterpolation"u8, out var degreeOfInterpolationProperty)) { - sampledFunctionParameterType.DependentParameterType.AddRange(jObject["dependentParameterType"].ToOrderedItemCollection()); + if(degreeOfInterpolationProperty.ValueKind == JsonValueKind.Null) + { + sampledFunctionParameterType.DegreeOfInterpolation = null; + } + else + { + sampledFunctionParameterType.DegreeOfInterpolation = degreeOfInterpolationProperty.GetInt32(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("dependentParameterType"u8, out var dependentParameterTypeProperty)) { - sampledFunctionParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + sampledFunctionParameterType.DependentParameterType.AddRange(dependentParameterTypeProperty.ToOrderedItemCollection()); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + sampledFunctionParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + sampledFunctionParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["independentParameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - sampledFunctionParameterType.IndependentParameterType.AddRange(jObject["independentParameterType"].ToOrderedItemCollection()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + sampledFunctionParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["interpolationPeriod"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("independentParameterType"u8, out var independentParameterTypeProperty)) + { + sampledFunctionParameterType.IndependentParameterType.AddRange(independentParameterTypeProperty.ToOrderedItemCollection()); + } + if (jsonElement.TryGetProperty("interpolationPeriod"u8, out var interpolationPeriodProperty)) { - sampledFunctionParameterType.InterpolationPeriod = SerializerHelper.ToValueArray(jObject["interpolationPeriod"].ToString()); + sampledFunctionParameterType.InterpolationPeriod = SerializerHelper.ToValueArray(interpolationPeriodProperty.GetString()); } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - sampledFunctionParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - sampledFunctionParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - sampledFunctionParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - sampledFunctionParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - sampledFunctionParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - sampledFunctionParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + } + else + { + sampledFunctionParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return sampledFunctionParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs index 99820ab71..fde46eb30 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ScaleReferenceQuantityValueResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var scaleReferenceQuantityValue = new CDP4Common.DTO.ScaleReferenceQuantityValue(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ScaleReferenceQuantityValueResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - scaleReferenceQuantityValue.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var scaleReferenceQuantityValue = new CDP4Common.DTO.ScaleReferenceQuantityValue(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - scaleReferenceQuantityValue.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + scaleReferenceQuantityValue.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - scaleReferenceQuantityValue.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + scaleReferenceQuantityValue.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - scaleReferenceQuantityValue.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + } + else + { + scaleReferenceQuantityValue.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - scaleReferenceQuantityValue.Scale = jObject["scale"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale scale property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + } + else + { + scaleReferenceQuantityValue.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - scaleReferenceQuantityValue.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + } + else + { + scaleReferenceQuantityValue.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - scaleReferenceQuantityValue.Value = jObject["value"].ToObject(); + if(valueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale value property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + } + else + { + scaleReferenceQuantityValue.Value = valueProperty.GetString(); + } } return scaleReferenceQuantityValue; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs index 1c92f405c..3979cde6d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ScaleValueDefinitionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var scaleValueDefinition = new CDP4Common.DTO.ScaleValueDefinition(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ScaleValueDefinitionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - scaleValueDefinition.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var scaleValueDefinition = new CDP4Common.DTO.ScaleValueDefinition(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - scaleValueDefinition.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + scaleValueDefinition.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - scaleValueDefinition.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + scaleValueDefinition.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - scaleValueDefinition.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + scaleValueDefinition.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - scaleValueDefinition.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + scaleValueDefinition.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - scaleValueDefinition.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + scaleValueDefinition.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - scaleValueDefinition.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + } + else + { + scaleValueDefinition.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - scaleValueDefinition.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + } + else + { + scaleValueDefinition.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - scaleValueDefinition.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + } + else + { + scaleValueDefinition.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - scaleValueDefinition.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + } + else + { + scaleValueDefinition.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - scaleValueDefinition.Value = jObject["value"].ToObject(); + if(valueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale value property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + } + else + { + scaleValueDefinition.Value = valueProperty.GetString(); + } } return scaleValueDefinition; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs index 5a1501b5b..9dbef1bc9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,140 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SectionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Section FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var section = new CDP4Common.DTO.Section(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SectionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - section.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var section = new CDP4Common.DTO.Section(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - section.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + section.Category.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - section.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the section {id} is null", section.Iid); + } + else + { + section.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - section.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + section.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - section.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + section.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - section.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the section {id} is null", section.Iid); + } + else + { + section.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - section.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the section {id} is null", section.Iid); + } + else + { + section.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - section.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the section {id} is null", section.Iid); + } + else + { + section.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["page"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("page"u8, out var pageProperty)) { - section.Page.AddRange(jObject["page"].ToOrderedItemCollection()); + section.Page.AddRange(pageProperty.ToOrderedItemCollection()); } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - section.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the section {id} is null", section.Iid); + } + else + { + section.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - section.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the section {id} is null", section.Iid); + } + else + { + section.ThingPreference = thingPreferenceProperty.GetString(); + } } return section; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs index e0a418fda..3508f96dd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,126 +28,243 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SharedStyleResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SharedStyle FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SharedStyle FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var sharedStyle = new CDP4Common.DTO.SharedStyle(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SharedStyleResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - sharedStyle.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var sharedStyle = new CDP4Common.DTO.SharedStyle(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - sharedStyle.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + sharedStyle.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - sharedStyle.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + sharedStyle.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fillColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fillColor"u8, out var fillColorProperty)) { - sharedStyle.FillColor = jObject["fillColor"].ToObject(); + if(fillColorProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FillColor = null; + } + else + { + sharedStyle.FillColor = fillColorProperty.GetGuid(); + } } - if (!jObject["fillOpacity"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fillOpacity"u8, out var fillOpacityProperty)) { - sharedStyle.FillOpacity = jObject["fillOpacity"].ToObject(); + if(fillOpacityProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FillOpacity = null; + } + else + { + sharedStyle.FillOpacity = fillOpacityProperty.GetSingle(); + } } - if (!jObject["fontBold"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontBold"u8, out var fontBoldProperty)) { - sharedStyle.FontBold = jObject["fontBold"].ToObject(); + if(fontBoldProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontBold = null; + } + else + { + sharedStyle.FontBold = fontBoldProperty.GetBoolean(); + } } - if (!jObject["fontColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontColor"u8, out var fontColorProperty)) { - sharedStyle.FontColor = jObject["fontColor"].ToObject(); + if(fontColorProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontColor = null; + } + else + { + sharedStyle.FontColor = fontColorProperty.GetGuid(); + } } - if (!jObject["fontItalic"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontItalic"u8, out var fontItalicProperty)) { - sharedStyle.FontItalic = jObject["fontItalic"].ToObject(); + if(fontItalicProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontItalic = null; + } + else + { + sharedStyle.FontItalic = fontItalicProperty.GetBoolean(); + } } - if (!jObject["fontName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontName"u8, out var fontNameProperty)) { - sharedStyle.FontName = jObject["fontName"].ToObject(); + if(fontNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale fontName property of the sharedStyle {id} is null", sharedStyle.Iid); + } + else + { + sharedStyle.FontName = fontNameProperty.GetString(); + } } - if (!jObject["fontSize"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontSize"u8, out var fontSizeProperty)) { - sharedStyle.FontSize = jObject["fontSize"].ToObject(); + if(fontSizeProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontSize = null; + } + else + { + sharedStyle.FontSize = fontSizeProperty.GetSingle(); + } } - if (!jObject["fontStrokeThrough"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontStrokeThrough"u8, out var fontStrokeThroughProperty)) { - sharedStyle.FontStrokeThrough = jObject["fontStrokeThrough"].ToObject(); + if(fontStrokeThroughProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontStrokeThrough = null; + } + else + { + sharedStyle.FontStrokeThrough = fontStrokeThroughProperty.GetBoolean(); + } } - if (!jObject["fontUnderline"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fontUnderline"u8, out var fontUnderlineProperty)) { - sharedStyle.FontUnderline = jObject["fontUnderline"].ToObject(); + if(fontUnderlineProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.FontUnderline = null; + } + else + { + sharedStyle.FontUnderline = fontUnderlineProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - sharedStyle.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the sharedStyle {id} is null", sharedStyle.Iid); + } + else + { + sharedStyle.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - sharedStyle.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the sharedStyle {id} is null", sharedStyle.Iid); + } + else + { + sharedStyle.Name = nameProperty.GetString(); + } } - if (!jObject["strokeColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeColor"u8, out var strokeColorProperty)) { - sharedStyle.StrokeColor = jObject["strokeColor"].ToObject(); + if(strokeColorProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.StrokeColor = null; + } + else + { + sharedStyle.StrokeColor = strokeColorProperty.GetGuid(); + } } - if (!jObject["strokeOpacity"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeOpacity"u8, out var strokeOpacityProperty)) { - sharedStyle.StrokeOpacity = jObject["strokeOpacity"].ToObject(); + if(strokeOpacityProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.StrokeOpacity = null; + } + else + { + sharedStyle.StrokeOpacity = strokeOpacityProperty.GetSingle(); + } } - if (!jObject["strokeWidth"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("strokeWidth"u8, out var strokeWidthProperty)) { - sharedStyle.StrokeWidth = jObject["strokeWidth"].ToObject(); + if(strokeWidthProperty.ValueKind == JsonValueKind.Null) + { + sharedStyle.StrokeWidth = null; + } + else + { + sharedStyle.StrokeWidth = strokeWidthProperty.GetSingle(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - sharedStyle.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the sharedStyle {id} is null", sharedStyle.Iid); + } + else + { + sharedStyle.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["usedColor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("usedColor"u8, out var usedColorProperty) && usedColorProperty.ValueKind != JsonValueKind.Null) { - sharedStyle.UsedColor.AddRange(jObject["usedColor"].ToObject>()); + foreach(var element in usedColorProperty.EnumerateArray()) + { + sharedStyle.UsedColor.Add(element.GetGuid()); + } } return sharedStyle; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs index 5ecd96249..bcc744308 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,107 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SimpleParameterValueResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SimpleParameterValue FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var simpleParameterValue = new CDP4Common.DTO.SimpleParameterValue(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SimpleParameterValue FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - simpleParameterValue.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the SimpleParameterValueResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - simpleParameterValue.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var simpleParameterValue = new CDP4Common.DTO.SimpleParameterValue(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - simpleParameterValue.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + simpleParameterValue.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - simpleParameterValue.ModifiedOn = jObject["modifiedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + simpleParameterValue.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - simpleParameterValue.ParameterType = jObject["parameterType"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + } + else + { + simpleParameterValue.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty)) { - simpleParameterValue.Scale = jObject["scale"].ToObject(); + if(parameterTypeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale parameterType property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + } + else + { + simpleParameterValue.ParameterType = parameterTypeProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty)) { - simpleParameterValue.ThingPreference = jObject["thingPreference"].ToObject(); + if(scaleProperty.ValueKind == JsonValueKind.Null) + { + simpleParameterValue.Scale = null; + } + else + { + simpleParameterValue.Scale = scaleProperty.GetGuid(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) + { + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + } + else + { + simpleParameterValue.ThingPreference = thingPreferenceProperty.GetString(); + } + } + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - simpleParameterValue.Value = SerializerHelper.ToValueArray(jObject["value"].ToString()); + simpleParameterValue.Value = SerializerHelper.ToValueArray(valueProperty.GetString()); } return simpleParameterValue; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs index c3fe38746..b7b864b58 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,191 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SimpleQuantityKindResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var simpleQuantityKind = new CDP4Common.DTO.SimpleQuantityKind(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SimpleQuantityKindResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - simpleQuantityKind.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var simpleQuantityKind = new CDP4Common.DTO.SimpleQuantityKind(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + simpleQuantityKind.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + simpleQuantityKind.Category.Add(element.GetGuid()); + } } - if (!jObject["defaultScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultScale"u8, out var defaultScaleProperty)) { - simpleQuantityKind.DefaultScale = jObject["defaultScale"].ToObject(); + if(defaultScaleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale defaultScale property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.DefaultScale = defaultScaleProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + simpleQuantityKind.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + simpleQuantityKind.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + simpleQuantityKind.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + simpleQuantityKind.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - simpleQuantityKind.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - simpleQuantityKind.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - simpleQuantityKind.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.Name = nameProperty.GetString(); + } } - if (!jObject["possibleScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleScale"u8, out var possibleScaleProperty) && possibleScaleProperty.ValueKind != JsonValueKind.Null) { - simpleQuantityKind.PossibleScale.AddRange(jObject["possibleScale"].ToObject>()); + foreach(var element in possibleScaleProperty.EnumerateArray()) + { + simpleQuantityKind.PossibleScale.Add(element.GetGuid()); + } } - if (!jObject["quantityDimensionSymbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("quantityDimensionSymbol"u8, out var quantityDimensionSymbolProperty)) { - simpleQuantityKind.QuantityDimensionSymbol = jObject["quantityDimensionSymbol"].ToObject(); + if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale quantityDimensionSymbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.QuantityDimensionSymbol = quantityDimensionSymbolProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - simpleQuantityKind.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - simpleQuantityKind.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - simpleQuantityKind.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + } + else + { + simpleQuantityKind.ThingPreference = thingPreferenceProperty.GetString(); + } } return simpleQuantityKind; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs index fe59a79b0..53ac8fc41 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SimpleUnitResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SimpleUnit FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var simpleUnit = new CDP4Common.DTO.SimpleUnit(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SimpleUnitResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - simpleUnit.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var simpleUnit = new CDP4Common.DTO.SimpleUnit(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - simpleUnit.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + simpleUnit.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - simpleUnit.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + simpleUnit.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - simpleUnit.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + simpleUnit.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - simpleUnit.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + simpleUnit.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - simpleUnit.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + simpleUnit.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - simpleUnit.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the simpleUnit {id} is null", simpleUnit.Iid); + } + else + { + simpleUnit.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - simpleUnit.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the simpleUnit {id} is null", simpleUnit.Iid); + } + else + { + simpleUnit.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - simpleUnit.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the simpleUnit {id} is null", simpleUnit.Iid); + } + else + { + simpleUnit.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - simpleUnit.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the simpleUnit {id} is null", simpleUnit.Iid); + } + else + { + simpleUnit.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - simpleUnit.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the simpleUnit {id} is null", simpleUnit.Iid); + } + else + { + simpleUnit.ThingPreference = thingPreferenceProperty.GetString(); + } } return simpleUnit; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs index 1b05618ef..2d60b0f17 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,155 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteDirectoryDataAnnotationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteDirectoryDataAnnotation = new CDP4Common.DTO.SiteDirectoryDataAnnotation(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteDirectoryDataAnnotationResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteDirectoryDataAnnotation.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var siteDirectoryDataAnnotation = new CDP4Common.DTO.SiteDirectoryDataAnnotation(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - siteDirectoryDataAnnotation.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.Author = authorProperty.GetGuid(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - siteDirectoryDataAnnotation.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - siteDirectoryDataAnnotation.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["discussion"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("discussion"u8, out var discussionProperty) && discussionProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataAnnotation.Discussion.AddRange(jObject["discussion"].ToObject>()); + foreach(var element in discussionProperty.EnumerateArray()) + { + siteDirectoryDataAnnotation.Discussion.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataAnnotation.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteDirectoryDataAnnotation.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataAnnotation.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteDirectoryDataAnnotation.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - siteDirectoryDataAnnotation.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteDirectoryDataAnnotation.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["primaryAnnotatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("primaryAnnotatedThing"u8, out var primaryAnnotatedThingProperty)) { - siteDirectoryDataAnnotation.PrimaryAnnotatedThing = jObject["primaryAnnotatedThing"].ToObject(); + if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale primaryAnnotatedThing property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.PrimaryAnnotatedThing = primaryAnnotatedThingProperty.GetGuid(); + } } - if (!jObject["relatedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("relatedThing"u8, out var relatedThingProperty) && relatedThingProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataAnnotation.RelatedThing.AddRange(jObject["relatedThing"].ToObject>()); + foreach(var element in relatedThingProperty.EnumerateArray()) + { + siteDirectoryDataAnnotation.RelatedThing.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteDirectoryDataAnnotation.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + } + else + { + siteDirectoryDataAnnotation.ThingPreference = thingPreferenceProperty.GetString(); + } } return siteDirectoryDataAnnotation; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs index 628d67c13..71d006535 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteDirectoryDataDiscussionItemResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteDirectoryDataDiscussionItem = new CDP4Common.DTO.SiteDirectoryDataDiscussionItem(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteDirectoryDataDiscussionItemResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteDirectoryDataDiscussionItem.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var siteDirectoryDataDiscussionItem = new CDP4Common.DTO.SiteDirectoryDataDiscussionItem(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - siteDirectoryDataDiscussionItem.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.Author = authorProperty.GetGuid(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - siteDirectoryDataDiscussionItem.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - siteDirectoryDataDiscussionItem.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataDiscussionItem.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteDirectoryDataDiscussionItem.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryDataDiscussionItem.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteDirectoryDataDiscussionItem.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - siteDirectoryDataDiscussionItem.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteDirectoryDataDiscussionItem.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["replyTo"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("replyTo"u8, out var replyToProperty)) { - siteDirectoryDataDiscussionItem.ReplyTo = jObject["replyTo"].ToObject(); + if(replyToProperty.ValueKind == JsonValueKind.Null) + { + siteDirectoryDataDiscussionItem.ReplyTo = null; + } + else + { + siteDirectoryDataDiscussionItem.ReplyTo = replyToProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteDirectoryDataDiscussionItem.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + } + else + { + siteDirectoryDataDiscussionItem.ThingPreference = thingPreferenceProperty.GetString(); + } } return siteDirectoryDataDiscussionItem; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs index adb6a5d1f..57db9f6e4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,141 +28,239 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteDirectoryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteDirectory FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteDirectory = new CDP4Common.DTO.SiteDirectory(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteDirectoryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteDirectory.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["annotation"].IsNullOrEmpty()) + var siteDirectory = new CDP4Common.DTO.SiteDirectory(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("annotation"u8, out var annotationProperty) && annotationProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.Annotation.AddRange(jObject["annotation"].ToObject>()); + foreach(var element in annotationProperty.EnumerateArray()) + { + siteDirectory.Annotation.Add(element.GetGuid()); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - siteDirectory.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["defaultParticipantRole"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultParticipantRole"u8, out var defaultParticipantRoleProperty)) { - siteDirectory.DefaultParticipantRole = jObject["defaultParticipantRole"].ToObject(); + if(defaultParticipantRoleProperty.ValueKind == JsonValueKind.Null) + { + siteDirectory.DefaultParticipantRole = null; + } + else + { + siteDirectory.DefaultParticipantRole = defaultParticipantRoleProperty.GetGuid(); + } } - if (!jObject["defaultPersonRole"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultPersonRole"u8, out var defaultPersonRoleProperty)) { - siteDirectory.DefaultPersonRole = jObject["defaultPersonRole"].ToObject(); + if(defaultPersonRoleProperty.ValueKind == JsonValueKind.Null) + { + siteDirectory.DefaultPersonRole = null; + } + else + { + siteDirectory.DefaultPersonRole = defaultPersonRoleProperty.GetGuid(); + } } - if (!jObject["domain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("domain"u8, out var domainProperty) && domainProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.Domain.AddRange(jObject["domain"].ToObject>()); + foreach(var element in domainProperty.EnumerateArray()) + { + siteDirectory.Domain.Add(element.GetGuid()); + } } - if (!jObject["domainGroup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("domainGroup"u8, out var domainGroupProperty) && domainGroupProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.DomainGroup.AddRange(jObject["domainGroup"].ToObject>()); + foreach(var element in domainGroupProperty.EnumerateArray()) + { + siteDirectory.DomainGroup.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteDirectory.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteDirectory.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["lastModifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("lastModifiedOn"u8, out var lastModifiedOnProperty)) { - siteDirectory.LastModifiedOn = jObject["lastModifiedOn"].ToObject(); + if(lastModifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale lastModifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.LastModifiedOn = lastModifiedOnProperty.GetDateTime(); + } } - if (!jObject["logEntry"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("logEntry"u8, out var logEntryProperty) && logEntryProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.LogEntry.AddRange(jObject["logEntry"].ToObject>()); + foreach(var element in logEntryProperty.EnumerateArray()) + { + siteDirectory.LogEntry.Add(element.GetGuid()); + } } - if (!jObject["model"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("model"u8, out var modelProperty) && modelProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.Model.AddRange(jObject["model"].ToObject>()); + foreach(var element in modelProperty.EnumerateArray()) + { + siteDirectory.Model.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteDirectory.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - siteDirectory.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.Name = nameProperty.GetString(); + } } - if (!jObject["naturalLanguage"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("naturalLanguage"u8, out var naturalLanguageProperty) && naturalLanguageProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.NaturalLanguage.AddRange(jObject["naturalLanguage"].ToObject>()); + foreach(var element in naturalLanguageProperty.EnumerateArray()) + { + siteDirectory.NaturalLanguage.Add(element.GetGuid()); + } } - if (!jObject["organization"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("organization"u8, out var organizationProperty) && organizationProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.Organization.AddRange(jObject["organization"].ToObject>()); + foreach(var element in organizationProperty.EnumerateArray()) + { + siteDirectory.Organization.Add(element.GetGuid()); + } } - if (!jObject["participantRole"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("participantRole"u8, out var participantRoleProperty) && participantRoleProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.ParticipantRole.AddRange(jObject["participantRole"].ToObject>()); + foreach(var element in participantRoleProperty.EnumerateArray()) + { + siteDirectory.ParticipantRole.Add(element.GetGuid()); + } } - if (!jObject["person"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("person"u8, out var personProperty) && personProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.Person.AddRange(jObject["person"].ToObject>()); + foreach(var element in personProperty.EnumerateArray()) + { + siteDirectory.Person.Add(element.GetGuid()); + } } - if (!jObject["personRole"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("personRole"u8, out var personRoleProperty) && personRoleProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.PersonRole.AddRange(jObject["personRole"].ToObject>()); + foreach(var element in personRoleProperty.EnumerateArray()) + { + siteDirectory.PersonRole.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - siteDirectory.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["siteReferenceDataLibrary"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("siteReferenceDataLibrary"u8, out var siteReferenceDataLibraryProperty) && siteReferenceDataLibraryProperty.ValueKind != JsonValueKind.Null) { - siteDirectory.SiteReferenceDataLibrary.AddRange(jObject["siteReferenceDataLibrary"].ToObject>()); + foreach(var element in siteReferenceDataLibraryProperty.EnumerateArray()) + { + siteDirectory.SiteReferenceDataLibrary.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteDirectory.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteDirectory {id} is null", siteDirectory.Iid); + } + else + { + siteDirectory.ThingPreference = thingPreferenceProperty.GetString(); + } } return siteDirectory; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs index ce8868802..28946bf18 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteDirectoryThingReferenceResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteDirectoryThingReference = new CDP4Common.DTO.SiteDirectoryThingReference(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteDirectoryThingReferenceResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteDirectoryThingReference.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var siteDirectoryThingReference = new CDP4Common.DTO.SiteDirectoryThingReference(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryThingReference.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteDirectoryThingReference.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteDirectoryThingReference.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteDirectoryThingReference.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteDirectoryThingReference.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + } + else + { + siteDirectoryThingReference.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["referencedRevisionNumber"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedRevisionNumber"u8, out var referencedRevisionNumberProperty)) { - siteDirectoryThingReference.ReferencedRevisionNumber = jObject["referencedRevisionNumber"].ToObject(); + if(referencedRevisionNumberProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referencedRevisionNumber property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + } + else + { + siteDirectoryThingReference.ReferencedRevisionNumber = referencedRevisionNumberProperty.GetInt32(); + } } - if (!jObject["referencedThing"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referencedThing"u8, out var referencedThingProperty)) { - siteDirectoryThingReference.ReferencedThing = jObject["referencedThing"].ToObject(); + if(referencedThingProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale referencedThing property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + } + else + { + siteDirectoryThingReference.ReferencedThing = referencedThingProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteDirectoryThingReference.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + } + else + { + siteDirectoryThingReference.ThingPreference = thingPreferenceProperty.GetString(); + } } return siteDirectoryThingReference; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs index 05fb25845..2e9c5fabe 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,101 +28,171 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteLogEntryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteLogEntry = new CDP4Common.DTO.SiteLogEntry(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteLogEntryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteLogEntry.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["affectedDomainIid"].IsNullOrEmpty()) + var siteLogEntry = new CDP4Common.DTO.SiteLogEntry(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("affectedDomainIid"u8, out var affectedDomainIidProperty) && affectedDomainIidProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.AffectedDomainIid.AddRange(jObject["affectedDomainIid"].ToObject>()); + foreach(var element in affectedDomainIidProperty.EnumerateArray()) + { + siteLogEntry.AffectedDomainIid.Add(element.GetGuid()); + } } - if (!jObject["affectedItemIid"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("affectedItemIid"u8, out var affectedItemIidProperty) && affectedItemIidProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.AffectedItemIid.AddRange(jObject["affectedItemIid"].ToObject>()); + foreach(var element in affectedItemIidProperty.EnumerateArray()) + { + siteLogEntry.AffectedItemIid.Add(element.GetGuid()); + } } - if (!jObject["author"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - siteLogEntry.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + siteLogEntry.Author = null; + } + else + { + siteLogEntry.Author = authorProperty.GetGuid(); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + siteLogEntry.Category.Add(element.GetGuid()); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - siteLogEntry.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - siteLogEntry.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteLogEntry.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteLogEntry.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - siteLogEntry.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["level"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("level"u8, out var levelProperty)) { - siteLogEntry.Level = jObject["level"].ToObject(); + if(levelProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale level property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.Level = LogLevelKindDeserializer.Deserialize(levelProperty); + } } - if (!jObject["logEntryChangelogItem"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("logEntryChangelogItem"u8, out var logEntryChangelogItemProperty) && logEntryChangelogItemProperty.ValueKind != JsonValueKind.Null) { - siteLogEntry.LogEntryChangelogItem.AddRange(jObject["logEntryChangelogItem"].ToObject>()); + foreach(var element in logEntryChangelogItemProperty.EnumerateArray()) + { + siteLogEntry.LogEntryChangelogItem.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteLogEntry.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteLogEntry.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteLogEntry {id} is null", siteLogEntry.Iid); + } + else + { + siteLogEntry.ThingPreference = thingPreferenceProperty.GetString(); + } } return siteLogEntry; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs index 1a16f8e9f..fc7c9afdf 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,151 +28,244 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SiteReferenceDataLibraryResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var siteReferenceDataLibrary = new CDP4Common.DTO.SiteReferenceDataLibrary(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SiteReferenceDataLibraryResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - siteReferenceDataLibrary.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var siteReferenceDataLibrary = new CDP4Common.DTO.SiteReferenceDataLibrary(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Alias.Add(element.GetGuid()); + } } - if (!jObject["baseQuantityKind"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("baseQuantityKind"u8, out var baseQuantityKindProperty)) { - siteReferenceDataLibrary.BaseQuantityKind.AddRange(jObject["baseQuantityKind"].ToOrderedItemCollection()); + siteReferenceDataLibrary.BaseQuantityKind.AddRange(baseQuantityKindProperty.ToOrderedItemCollection()); } - if (!jObject["baseUnit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("baseUnit"u8, out var baseUnitProperty) && baseUnitProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.BaseUnit.AddRange(jObject["baseUnit"].ToObject>()); + foreach(var element in baseUnitProperty.EnumerateArray()) + { + siteReferenceDataLibrary.BaseUnit.Add(element.GetGuid()); + } } - if (!jObject["constant"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("constant"u8, out var constantProperty) && constantProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Constant.AddRange(jObject["constant"].ToObject>()); + foreach(var element in constantProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Constant.Add(element.GetGuid()); + } } - if (!jObject["definedCategory"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definedCategory"u8, out var definedCategoryProperty) && definedCategoryProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.DefinedCategory.AddRange(jObject["definedCategory"].ToObject>()); + foreach(var element in definedCategoryProperty.EnumerateArray()) + { + siteReferenceDataLibrary.DefinedCategory.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + siteReferenceDataLibrary.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + siteReferenceDataLibrary.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["fileType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("fileType"u8, out var fileTypeProperty) && fileTypeProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.FileType.AddRange(jObject["fileType"].ToObject>()); + foreach(var element in fileTypeProperty.EnumerateArray()) + { + siteReferenceDataLibrary.FileType.Add(element.GetGuid()); + } } - if (!jObject["glossary"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("glossary"u8, out var glossaryProperty) && glossaryProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Glossary.AddRange(jObject["glossary"].ToObject>()); + foreach(var element in glossaryProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Glossary.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + siteReferenceDataLibrary.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - siteReferenceDataLibrary.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + } + else + { + siteReferenceDataLibrary.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - siteReferenceDataLibrary.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + } + else + { + siteReferenceDataLibrary.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - siteReferenceDataLibrary.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + } + else + { + siteReferenceDataLibrary.Name = nameProperty.GetString(); + } } - if (!jObject["parameterType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("parameterType"u8, out var parameterTypeProperty) && parameterTypeProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.ParameterType.AddRange(jObject["parameterType"].ToObject>()); + foreach(var element in parameterTypeProperty.EnumerateArray()) + { + siteReferenceDataLibrary.ParameterType.Add(element.GetGuid()); + } } - if (!jObject["referenceSource"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("referenceSource"u8, out var referenceSourceProperty) && referenceSourceProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.ReferenceSource.AddRange(jObject["referenceSource"].ToObject>()); + foreach(var element in referenceSourceProperty.EnumerateArray()) + { + siteReferenceDataLibrary.ReferenceSource.Add(element.GetGuid()); + } } - if (!jObject["requiredRdl"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requiredRdl"u8, out var requiredRdlProperty)) { - siteReferenceDataLibrary.RequiredRdl = jObject["requiredRdl"].ToObject(); + if(requiredRdlProperty.ValueKind == JsonValueKind.Null) + { + siteReferenceDataLibrary.RequiredRdl = null; + } + else + { + siteReferenceDataLibrary.RequiredRdl = requiredRdlProperty.GetGuid(); + } } - if (!jObject["rule"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("rule"u8, out var ruleProperty) && ruleProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Rule.AddRange(jObject["rule"].ToObject>()); + foreach(var element in ruleProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Rule.Add(element.GetGuid()); + } } - if (!jObject["scale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("scale"u8, out var scaleProperty) && scaleProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Scale.AddRange(jObject["scale"].ToObject>()); + foreach(var element in scaleProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Scale.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - siteReferenceDataLibrary.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + } + else + { + siteReferenceDataLibrary.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - siteReferenceDataLibrary.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + } + else + { + siteReferenceDataLibrary.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty) && unitProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.Unit.AddRange(jObject["unit"].ToObject>()); + foreach(var element in unitProperty.EnumerateArray()) + { + siteReferenceDataLibrary.Unit.Add(element.GetGuid()); + } } - if (!jObject["unitPrefix"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unitPrefix"u8, out var unitPrefixProperty) && unitPrefixProperty.ValueKind != JsonValueKind.Null) { - siteReferenceDataLibrary.UnitPrefix.AddRange(jObject["unitPrefix"].ToObject>()); + foreach(var element in unitPrefixProperty.EnumerateArray()) + { + siteReferenceDataLibrary.UnitPrefix.Add(element.GetGuid()); + } } return siteReferenceDataLibrary; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs index f0f54c898..37940cf95 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SolutionResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Solution FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var solution = new CDP4Common.DTO.Solution(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SolutionResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - solution.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["author"].IsNullOrEmpty()) + var solution = new CDP4Common.DTO.Solution(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("author"u8, out var authorProperty)) { - solution.Author = jObject["author"].ToObject(); + if(authorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale author property of the solution {id} is null", solution.Iid); + } + else + { + solution.Author = authorProperty.GetGuid(); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - solution.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the solution {id} is null", solution.Iid); + } + else + { + solution.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - solution.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the solution {id} is null", solution.Iid); + } + else + { + solution.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - solution.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + solution.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - solution.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + solution.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - solution.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the solution {id} is null", solution.Iid); + } + else + { + solution.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - solution.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the solution {id} is null", solution.Iid); + } + else + { + solution.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - solution.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the solution {id} is null", solution.Iid); + } + else + { + solution.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - solution.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the solution {id} is null", solution.Iid); + } + else + { + solution.ThingPreference = thingPreferenceProperty.GetString(); + } } return solution; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs index 128fae7d7..dc593f909 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,116 +28,203 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class SpecializedQuantityKindResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var specializedQuantityKind = new CDP4Common.DTO.SpecializedQuantityKind(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the SpecializedQuantityKindResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - specializedQuantityKind.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var specializedQuantityKind = new CDP4Common.DTO.SpecializedQuantityKind(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + specializedQuantityKind.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + specializedQuantityKind.Category.Add(element.GetGuid()); + } } - if (!jObject["defaultScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("defaultScale"u8, out var defaultScaleProperty)) { - specializedQuantityKind.DefaultScale = jObject["defaultScale"].ToObject(); + if(defaultScaleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale defaultScale property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.DefaultScale = defaultScaleProperty.GetGuid(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + specializedQuantityKind.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + specializedQuantityKind.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + specializedQuantityKind.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["general"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("general"u8, out var generalProperty)) { - specializedQuantityKind.General = jObject["general"].ToObject(); + if(generalProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale general property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.General = generalProperty.GetGuid(); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + specializedQuantityKind.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - specializedQuantityKind.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - specializedQuantityKind.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - specializedQuantityKind.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.Name = nameProperty.GetString(); + } } - if (!jObject["possibleScale"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("possibleScale"u8, out var possibleScaleProperty) && possibleScaleProperty.ValueKind != JsonValueKind.Null) { - specializedQuantityKind.PossibleScale.AddRange(jObject["possibleScale"].ToObject>()); + foreach(var element in possibleScaleProperty.EnumerateArray()) + { + specializedQuantityKind.PossibleScale.Add(element.GetGuid()); + } } - if (!jObject["quantityDimensionSymbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("quantityDimensionSymbol"u8, out var quantityDimensionSymbolProperty)) { - specializedQuantityKind.QuantityDimensionSymbol = jObject["quantityDimensionSymbol"].ToObject(); + if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale quantityDimensionSymbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.QuantityDimensionSymbol = quantityDimensionSymbolProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - specializedQuantityKind.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - specializedQuantityKind.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - specializedQuantityKind.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + } + else + { + specializedQuantityKind.ThingPreference = thingPreferenceProperty.GetString(); + } } return specializedQuantityKind; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs index ff54c2602..2a3d0bc4f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,111 +28,175 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class StakeHolderValueMapResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var stakeHolderValueMap = new CDP4Common.DTO.StakeHolderValueMap(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the StakeHolderValueMapResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - stakeHolderValueMap.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var stakeHolderValueMap = new CDP4Common.DTO.StakeHolderValueMap(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + stakeHolderValueMap.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + stakeHolderValueMap.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + stakeHolderValueMap.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + stakeHolderValueMap.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + stakeHolderValueMap.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["goal"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("goal"u8, out var goalProperty) && goalProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Goal.AddRange(jObject["goal"].ToObject>()); + foreach(var element in goalProperty.EnumerateArray()) + { + stakeHolderValueMap.Goal.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + stakeHolderValueMap.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - stakeHolderValueMap.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + } + else + { + stakeHolderValueMap.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - stakeHolderValueMap.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + } + else + { + stakeHolderValueMap.Name = nameProperty.GetString(); + } } - if (!jObject["requirement"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("requirement"u8, out var requirementProperty) && requirementProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Requirement.AddRange(jObject["requirement"].ToObject>()); + foreach(var element in requirementProperty.EnumerateArray()) + { + stakeHolderValueMap.Requirement.Add(element.GetGuid()); + } } - if (!jObject["settings"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("settings"u8, out var settingsProperty) && settingsProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.Settings.AddRange(jObject["settings"].ToObject>()); + foreach(var element in settingsProperty.EnumerateArray()) + { + stakeHolderValueMap.Settings.Add(element.GetGuid()); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - stakeHolderValueMap.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + } + else + { + stakeHolderValueMap.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["stakeholderValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholderValue"u8, out var stakeholderValueProperty) && stakeholderValueProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.StakeholderValue.AddRange(jObject["stakeholderValue"].ToObject>()); + foreach(var element in stakeholderValueProperty.EnumerateArray()) + { + stakeHolderValueMap.StakeholderValue.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - stakeHolderValueMap.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + } + else + { + stakeHolderValueMap.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueGroup"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueGroup"u8, out var valueGroupProperty) && valueGroupProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMap.ValueGroup.AddRange(jObject["valueGroup"].ToObject>()); + foreach(var element in valueGroupProperty.EnumerateArray()) + { + stakeHolderValueMap.ValueGroup.Add(element.GetGuid()); + } } return stakeHolderValueMap; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs index efb0af6bd..cf611c630 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,71 +28,115 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class StakeHolderValueMapSettingsResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.StakeHolderValueMapSettings FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.StakeHolderValueMapSettings FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var stakeHolderValueMapSettings = new CDP4Common.DTO.StakeHolderValueMapSettings(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the StakeHolderValueMapSettingsResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - stakeHolderValueMapSettings.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var stakeHolderValueMapSettings = new CDP4Common.DTO.StakeHolderValueMapSettings(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMapSettings.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + stakeHolderValueMapSettings.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - stakeHolderValueMapSettings.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + stakeHolderValueMapSettings.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["goalToValueGroupRelationship"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("goalToValueGroupRelationship"u8, out var goalToValueGroupRelationshipProperty)) { - stakeHolderValueMapSettings.GoalToValueGroupRelationship = jObject["goalToValueGroupRelationship"].ToObject(); + if(goalToValueGroupRelationshipProperty.ValueKind == JsonValueKind.Null) + { + stakeHolderValueMapSettings.GoalToValueGroupRelationship = null; + } + else + { + stakeHolderValueMapSettings.GoalToValueGroupRelationship = goalToValueGroupRelationshipProperty.GetGuid(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - stakeHolderValueMapSettings.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); + } + else + { + stakeHolderValueMapSettings.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["stakeholderValueToRequirementRelationship"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholderValueToRequirementRelationship"u8, out var stakeholderValueToRequirementRelationshipProperty)) { - stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship = jObject["stakeholderValueToRequirementRelationship"].ToObject(); + if(stakeholderValueToRequirementRelationshipProperty.ValueKind == JsonValueKind.Null) + { + stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship = null; + } + else + { + stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship = stakeholderValueToRequirementRelationshipProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - stakeHolderValueMapSettings.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); + } + else + { + stakeHolderValueMapSettings.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["valueGroupToStakeholderValueRelationship"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("valueGroupToStakeholderValueRelationship"u8, out var valueGroupToStakeholderValueRelationshipProperty)) { - stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship = jObject["valueGroupToStakeholderValueRelationship"].ToObject(); + if(valueGroupToStakeholderValueRelationshipProperty.ValueKind == JsonValueKind.Null) + { + stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship = null; + } + else + { + stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship = valueGroupToStakeholderValueRelationshipProperty.GetGuid(); + } } return stakeHolderValueMapSettings; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs index df57145da..36e471fef 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,143 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class StakeholderResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Stakeholder FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Stakeholder FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var stakeholder = new CDP4Common.DTO.Stakeholder(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the StakeholderResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - stakeholder.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var stakeholder = new CDP4Common.DTO.Stakeholder(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - stakeholder.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + stakeholder.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - stakeholder.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + stakeholder.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - stakeholder.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + stakeholder.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - stakeholder.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + stakeholder.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - stakeholder.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + stakeholder.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - stakeholder.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + stakeholder.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - stakeholder.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the stakeholder {id} is null", stakeholder.Iid); + } + else + { + stakeholder.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - stakeholder.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the stakeholder {id} is null", stakeholder.Iid); + } + else + { + stakeholder.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - stakeholder.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the stakeholder {id} is null", stakeholder.Iid); + } + else + { + stakeholder.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["stakeholderValue"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("stakeholderValue"u8, out var stakeholderValueProperty) && stakeholderValueProperty.ValueKind != JsonValueKind.Null) { - stakeholder.StakeholderValue.AddRange(jObject["stakeholderValue"].ToObject>()); + foreach(var element in stakeholderValueProperty.EnumerateArray()) + { + stakeholder.StakeholderValue.Add(element.GetGuid()); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - stakeholder.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the stakeholder {id} is null", stakeholder.Iid); + } + else + { + stakeholder.ThingPreference = thingPreferenceProperty.GetString(); + } } return stakeholder; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs index 36af14699..be7fa1876 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,135 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class StakeholderValueResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.StakeholderValue FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.StakeholderValue FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var stakeholderValue = new CDP4Common.DTO.StakeholderValue(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the StakeholderValueResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - stakeholderValue.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var stakeholderValue = new CDP4Common.DTO.StakeholderValue(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + stakeholderValue.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + stakeholderValue.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + stakeholderValue.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + stakeholderValue.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + stakeholderValue.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - stakeholderValue.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + stakeholderValue.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - stakeholderValue.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the stakeholderValue {id} is null", stakeholderValue.Iid); + } + else + { + stakeholderValue.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - stakeholderValue.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the stakeholderValue {id} is null", stakeholderValue.Iid); + } + else + { + stakeholderValue.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - stakeholderValue.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the stakeholderValue {id} is null", stakeholderValue.Iid); + } + else + { + stakeholderValue.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - stakeholderValue.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the stakeholderValue {id} is null", stakeholderValue.Iid); + } + else + { + stakeholderValue.ThingPreference = thingPreferenceProperty.GetString(); + } } return stakeholderValue; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs index 47dbc2b2d..775ad6bde 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,99 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class TelephoneNumberResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.TelephoneNumber FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.TelephoneNumber FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var telephoneNumber = new CDP4Common.DTO.TelephoneNumber(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the TelephoneNumberResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - telephoneNumber.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var telephoneNumber = new CDP4Common.DTO.TelephoneNumber(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - telephoneNumber.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + telephoneNumber.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - telephoneNumber.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + telephoneNumber.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - telephoneNumber.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the telephoneNumber {id} is null", telephoneNumber.Iid); + } + else + { + telephoneNumber.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - telephoneNumber.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the telephoneNumber {id} is null", telephoneNumber.Iid); + } + else + { + telephoneNumber.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - telephoneNumber.Value = jObject["value"].ToObject(); + if(valueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale value property of the telephoneNumber {id} is null", telephoneNumber.Iid); + } + else + { + telephoneNumber.Value = valueProperty.GetString(); + } } - if (!jObject["vcardType"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("vcardType"u8, out var vcardTypeProperty) && vcardTypeProperty.ValueKind != JsonValueKind.Null) { - telephoneNumber.VcardType.AddRange(jObject["vcardType"].ToObject>()); + foreach(var element in vcardTypeProperty.EnumerateArray()) + { + telephoneNumber.VcardType.Add(VcardTelephoneNumberKindDeserializer.Deserialize(element)); + } } return telephoneNumber; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs index 0b1567f9a..a2a92daa0 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,139 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class TermResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.Term FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var term = new CDP4Common.DTO.Term(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the TermResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - term.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var term = new CDP4Common.DTO.Term(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - term.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + term.Alias.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - term.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + term.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - term.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + term.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - term.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + term.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - term.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + term.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - term.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the term {id} is null", term.Iid); + } + else + { + term.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - term.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the term {id} is null", term.Iid); + } + else + { + term.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - term.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the term {id} is null", term.Iid); + } + else + { + term.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - term.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the term {id} is null", term.Iid); + } + else + { + term.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - term.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the term {id} is null", term.Iid); + } + else + { + term.ThingPreference = thingPreferenceProperty.GetString(); + } } return term; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs index 744222680..c88507401 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class TextParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.TextParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var textParameterType = new CDP4Common.DTO.TextParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the TextParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - textParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var textParameterType = new CDP4Common.DTO.TextParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - textParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + textParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - textParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + textParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - textParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + textParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - textParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + textParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - textParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + textParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - textParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + textParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - textParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - textParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - textParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - textParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - textParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - textParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the textParameterType {id} is null", textParameterType.Iid); + } + else + { + textParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return textParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs index 4b6fbb167..490706e1d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class TextualNoteResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.TextualNote FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var textualNote = new CDP4Common.DTO.TextualNote(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the TextualNoteResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - textualNote.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["category"].IsNullOrEmpty()) + var textualNote = new CDP4Common.DTO.TextualNote(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - textualNote.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + textualNote.Category.Add(element.GetGuid()); + } } - if (!jObject["content"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("content"u8, out var contentProperty)) { - textualNote.Content = jObject["content"].ToObject(); + if(contentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale content property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.Content = contentProperty.GetString(); + } } - if (!jObject["createdOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("createdOn"u8, out var createdOnProperty)) { - textualNote.CreatedOn = jObject["createdOn"].ToObject(); + if(createdOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale createdOn property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.CreatedOn = createdOnProperty.GetDateTime(); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - textualNote.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + textualNote.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - textualNote.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + textualNote.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["languageCode"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("languageCode"u8, out var languageCodeProperty)) { - textualNote.LanguageCode = jObject["languageCode"].ToObject(); + if(languageCodeProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale languageCode property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.LanguageCode = languageCodeProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - textualNote.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - textualNote.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.Name = nameProperty.GetString(); + } } - if (!jObject["owner"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("owner"u8, out var ownerProperty)) { - textualNote.Owner = jObject["owner"].ToObject(); + if(ownerProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale owner property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.Owner = ownerProperty.GetGuid(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - textualNote.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - textualNote.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the textualNote {id} is null", textualNote.Iid); + } + else + { + textualNote.ThingPreference = thingPreferenceProperty.GetString(); + } } return textualNote; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs index dc2467aa2..218e355c7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,96 +28,159 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class TimeOfDayParameterTypeResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var timeOfDayParameterType = new CDP4Common.DTO.TimeOfDayParameterType(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the TimeOfDayParameterTypeResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - timeOfDayParameterType.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var timeOfDayParameterType = new CDP4Common.DTO.TimeOfDayParameterType(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + timeOfDayParameterType.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + timeOfDayParameterType.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + timeOfDayParameterType.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + timeOfDayParameterType.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + timeOfDayParameterType.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - timeOfDayParameterType.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + timeOfDayParameterType.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - timeOfDayParameterType.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - timeOfDayParameterType.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - timeOfDayParameterType.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - timeOfDayParameterType.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["symbol"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("symbol"u8, out var symbolProperty)) { - timeOfDayParameterType.Symbol = jObject["symbol"].ToObject(); + if(symbolProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale symbol property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.Symbol = symbolProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - timeOfDayParameterType.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + } + else + { + timeOfDayParameterType.ThingPreference = thingPreferenceProperty.GetString(); + } } return timeOfDayParameterType; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs index 9deaa29e9..147ac291c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class UnitFactorResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.UnitFactor FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.UnitFactor FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var unitFactor = new CDP4Common.DTO.UnitFactor(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the UnitFactorResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - unitFactor.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var unitFactor = new CDP4Common.DTO.UnitFactor(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - unitFactor.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + unitFactor.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - unitFactor.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + unitFactor.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["exponent"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("exponent"u8, out var exponentProperty)) { - unitFactor.Exponent = jObject["exponent"].ToObject(); + if(exponentProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale exponent property of the unitFactor {id} is null", unitFactor.Iid); + } + else + { + unitFactor.Exponent = exponentProperty.GetString(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - unitFactor.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the unitFactor {id} is null", unitFactor.Iid); + } + else + { + unitFactor.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - unitFactor.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the unitFactor {id} is null", unitFactor.Iid); + } + else + { + unitFactor.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["unit"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("unit"u8, out var unitProperty)) { - unitFactor.Unit = jObject["unit"].ToObject(); + if(unitProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale unit property of the unitFactor {id} is null", unitFactor.Iid); + } + else + { + unitFactor.Unit = unitProperty.GetGuid(); + } } return unitFactor; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs index f946c2757..9abd0988b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,91 +28,151 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class UnitPrefixResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.UnitPrefix FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var unitPrefix = new CDP4Common.DTO.UnitPrefix(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the UnitPrefixResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - unitPrefix.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var unitPrefix = new CDP4Common.DTO.UnitPrefix(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - unitPrefix.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + unitPrefix.Alias.Add(element.GetGuid()); + } } - if (!jObject["conversionFactor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("conversionFactor"u8, out var conversionFactorProperty)) { - unitPrefix.ConversionFactor = jObject["conversionFactor"].ToObject(); + if(conversionFactorProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale conversionFactor property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.ConversionFactor = conversionFactorProperty.GetString(); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - unitPrefix.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + unitPrefix.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - unitPrefix.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + unitPrefix.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - unitPrefix.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + unitPrefix.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - unitPrefix.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + unitPrefix.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["isDeprecated"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isDeprecated"u8, out var isDeprecatedProperty)) { - unitPrefix.IsDeprecated = jObject["isDeprecated"].ToObject(); + if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isDeprecated property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.IsDeprecated = isDeprecatedProperty.GetBoolean(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - unitPrefix.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - unitPrefix.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - unitPrefix.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - unitPrefix.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the unitPrefix {id} is null", unitPrefix.Iid); + } + else + { + unitPrefix.ThingPreference = thingPreferenceProperty.GetString(); + } } return unitPrefix; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs index da543c27c..5a3ec842c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,66 +28,103 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class UserPreferenceResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.UserPreference FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.UserPreference FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var userPreference = new CDP4Common.DTO.UserPreference(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the UserPreferenceResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - userPreference.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + var userPreference = new CDP4Common.DTO.UserPreference(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - userPreference.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + userPreference.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - userPreference.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + userPreference.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - userPreference.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the userPreference {id} is null", userPreference.Iid); + } + else + { + userPreference.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - userPreference.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the userPreference {id} is null", userPreference.Iid); + } + else + { + userPreference.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - userPreference.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the userPreference {id} is null", userPreference.Iid); + } + else + { + userPreference.ThingPreference = thingPreferenceProperty.GetString(); + } } - if (!jObject["value"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("value"u8, out var valueProperty)) { - userPreference.Value = jObject["value"].ToObject(); + if(valueProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale value property of the userPreference {id} is null", userPreference.Iid); + } + else + { + userPreference.Value = valueProperty.GetString(); + } } return userPreference; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs index 577879294..55801be0e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,81 +28,127 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class UserRuleVerificationResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JObject jObject) - { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var userRuleVerification = new CDP4Common.DTO.UserRuleVerification(iid, revisionNumber); + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); - if (!jObject["actor"].IsNullOrEmpty()) + /// + /// Instantiate and deserialize the properties of a + /// + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jsonElement) + { + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) { - userRuleVerification.Actor = jObject["actor"].ToObject(); + throw new DeSerializationException("the mandatory iid property is not available, the UserRuleVerificationResolver cannot be used to deserialize this JsonElement"); } + + var revisionNumberValue = 0; - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - userRuleVerification.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + var userRuleVerification = new CDP4Common.DTO.UserRuleVerification(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - userRuleVerification.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + userRuleVerification.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["executedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - userRuleVerification.ExecutedOn = jObject["executedOn"].ToObject(); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + userRuleVerification.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["isActive"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("executedOn"u8, out var executedOnProperty)) { - userRuleVerification.IsActive = jObject["isActive"].ToObject(); + if(executedOnProperty.ValueKind == JsonValueKind.Null) + { + userRuleVerification.ExecutedOn = null; + } + else + { + userRuleVerification.ExecutedOn = executedOnProperty.GetDateTime(); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("isActive"u8, out var isActiveProperty)) { - userRuleVerification.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(isActiveProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale isActive property of the userRuleVerification {id} is null", userRuleVerification.Iid); + } + else + { + userRuleVerification.IsActive = isActiveProperty.GetBoolean(); + } } - if (!jObject["rule"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - userRuleVerification.Rule = jObject["rule"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the userRuleVerification {id} is null", userRuleVerification.Iid); + } + else + { + userRuleVerification.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["status"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("rule"u8, out var ruleProperty)) { - userRuleVerification.Status = jObject["status"].ToObject(); + if(ruleProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale rule property of the userRuleVerification {id} is null", userRuleVerification.Iid); + } + else + { + userRuleVerification.Rule = ruleProperty.GetGuid(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("status"u8, out var statusProperty)) { - userRuleVerification.ThingPreference = jObject["thingPreference"].ToObject(); + if(statusProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale status property of the userRuleVerification {id} is null", userRuleVerification.Iid); + } + else + { + userRuleVerification.Status = RuleVerificationStatusKindDeserializer.Deserialize(statusProperty); + } } - if (!jObject["violation"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - userRuleVerification.Violation.AddRange(jObject["violation"].ToObject>()); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the userRuleVerification {id} is null", userRuleVerification.Iid); + } + else + { + userRuleVerification.ThingPreference = thingPreferenceProperty.GetString(); + } } return userRuleVerification; diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs index 6ae2c601c..8fe97a0b4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -28,86 +28,135 @@ namespace CDP4JsonSerializer { - using System; - using System.Collections.Generic; + using System.Text.Json; - using CDP4Common.CommonData; - using CDP4Common.DiagramData; - using CDP4Common.EngineeringModelData; - using CDP4Common.ReportingData; - using CDP4Common.SiteDirectoryData; - - using Newtonsoft.Json.Linq; + using NLog; /// - /// The purpose of the is to deserialize a JSON object to a + /// The purpose of the is to deserialize a JSON object to a /// public static class ValueGroupResolver { /// - /// Instantiate and deserialize the properties of a + /// The NLog logger + /// + private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + + /// + /// Instantiate and deserialize the properties of a /// - /// The containing the data - /// The to instantiate - public static CDP4Common.DTO.ValueGroup FromJsonObject(JObject jObject) + /// The containing the data + /// The to instantiate + public static CDP4Common.DTO.ValueGroup FromJsonObject(JsonElement jsonElement) { - var iid = jObject["iid"].ToObject(); - var revisionNumber = jObject["revisionNumber"].IsNullOrEmpty() ? 0 : jObject["revisionNumber"].ToObject(); - var valueGroup = new CDP4Common.DTO.ValueGroup(iid, revisionNumber); + if (!jsonElement.TryGetProperty("iid"u8, out var iid)) + { + throw new DeSerializationException("the mandatory iid property is not available, the ValueGroupResolver cannot be used to deserialize this JsonElement"); + } + + var revisionNumberValue = 0; - if (!jObject["actor"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("revisionNumber"u8, out var revisionNumber)) { - valueGroup.Actor = jObject["actor"].ToObject(); + revisionNumberValue = revisionNumber.GetInt32(); } - if (!jObject["alias"].IsNullOrEmpty()) + var valueGroup = new CDP4Common.DTO.ValueGroup(iid.GetGuid(), revisionNumberValue); + + if (jsonElement.TryGetProperty("alias"u8, out var aliasProperty) && aliasProperty.ValueKind != JsonValueKind.Null) { - valueGroup.Alias.AddRange(jObject["alias"].ToObject>()); + foreach(var element in aliasProperty.EnumerateArray()) + { + valueGroup.Alias.Add(element.GetGuid()); + } } - if (!jObject["category"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("category"u8, out var categoryProperty) && categoryProperty.ValueKind != JsonValueKind.Null) { - valueGroup.Category.AddRange(jObject["category"].ToObject>()); + foreach(var element in categoryProperty.EnumerateArray()) + { + valueGroup.Category.Add(element.GetGuid()); + } } - if (!jObject["definition"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("definition"u8, out var definitionProperty) && definitionProperty.ValueKind != JsonValueKind.Null) { - valueGroup.Definition.AddRange(jObject["definition"].ToObject>()); + foreach(var element in definitionProperty.EnumerateArray()) + { + valueGroup.Definition.Add(element.GetGuid()); + } } - if (!jObject["excludedDomain"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedDomain"u8, out var excludedDomainProperty) && excludedDomainProperty.ValueKind != JsonValueKind.Null) { - valueGroup.ExcludedDomain.AddRange(jObject["excludedDomain"].ToObject>()); + foreach(var element in excludedDomainProperty.EnumerateArray()) + { + valueGroup.ExcludedDomain.Add(element.GetGuid()); + } } - if (!jObject["excludedPerson"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("excludedPerson"u8, out var excludedPersonProperty) && excludedPersonProperty.ValueKind != JsonValueKind.Null) { - valueGroup.ExcludedPerson.AddRange(jObject["excludedPerson"].ToObject>()); + foreach(var element in excludedPersonProperty.EnumerateArray()) + { + valueGroup.ExcludedPerson.Add(element.GetGuid()); + } } - if (!jObject["hyperLink"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("hyperLink"u8, out var hyperLinkProperty) && hyperLinkProperty.ValueKind != JsonValueKind.Null) { - valueGroup.HyperLink.AddRange(jObject["hyperLink"].ToObject>()); + foreach(var element in hyperLinkProperty.EnumerateArray()) + { + valueGroup.HyperLink.Add(element.GetGuid()); + } } - if (!jObject["modifiedOn"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("modifiedOn"u8, out var modifiedOnProperty)) { - valueGroup.ModifiedOn = jObject["modifiedOn"].ToObject(); + if(modifiedOnProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale modifiedOn property of the valueGroup {id} is null", valueGroup.Iid); + } + else + { + valueGroup.ModifiedOn = modifiedOnProperty.GetDateTime(); + } } - if (!jObject["name"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("name"u8, out var nameProperty)) { - valueGroup.Name = jObject["name"].ToObject(); + if(nameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale name property of the valueGroup {id} is null", valueGroup.Iid); + } + else + { + valueGroup.Name = nameProperty.GetString(); + } } - if (!jObject["shortName"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("shortName"u8, out var shortNameProperty)) { - valueGroup.ShortName = jObject["shortName"].ToObject(); + if(shortNameProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale shortName property of the valueGroup {id} is null", valueGroup.Iid); + } + else + { + valueGroup.ShortName = shortNameProperty.GetString(); + } } - if (!jObject["thingPreference"].IsNullOrEmpty()) + if (jsonElement.TryGetProperty("thingPreference"u8, out var thingPreferenceProperty)) { - valueGroup.ThingPreference = jObject["thingPreference"].ToObject(); + if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) + { + Logger.Debug("The non-nullabale thingPreference property of the valueGroup {id} is null", valueGroup.Iid); + } + else + { + valueGroup.ThingPreference = thingPreferenceProperty.GetString(); + } } return valueGroup; diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs index 52d716205..50c743b8a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ActionItem = CDP4Common.DTO.ActionItem; /// /// The purpose of the class is to provide a specific serializer @@ -44,103 +50,1079 @@ namespace CDP4JsonSerializer public class ActionItemSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actionee", actionee => new JValue(actionee) }, - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "closeOutDate", closeOutDate => new JValue(closeOutDate != null ? ((DateTime)closeOutDate).ToString("yyyy-MM-ddTHH:mm:ss.fffZ") : null) }, - { "closeOutStatement", closeOutStatement => new JValue(closeOutStatement) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "dueDate", dueDate => new JValue(((DateTime)dueDate).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ActionItem actionItem) - { - var jsonObject = new JObject(); - jsonObject.Add("actionee", this.PropertySerializerMap["actionee"](actionItem.Actionee)); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](actionItem.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](actionItem.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](actionItem.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), actionItem.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), actionItem.ClassKind))); - jsonObject.Add("closeOutDate", this.PropertySerializerMap["closeOutDate"](actionItem.CloseOutDate)); - jsonObject.Add("closeOutStatement", this.PropertySerializerMap["closeOutStatement"](actionItem.CloseOutStatement)); - jsonObject.Add("content", this.PropertySerializerMap["content"](actionItem.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](actionItem.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](actionItem.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("dueDate", this.PropertySerializerMap["dueDate"](actionItem.DueDate)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](actionItem.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](actionItem.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](actionItem.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](actionItem.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](actionItem.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](actionItem.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](actionItem.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](actionItem.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](actionItem.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](actionItem.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](actionItem.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), actionItem.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](actionItem.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](actionItem.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actionee": + var allowedVersionsForActionee = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActionee.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actionee"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; + + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "closeoutdate": + var allowedVersionsForCloseOutDate = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCloseOutDate.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("closeOutDate"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "closeoutstatement": + var allowedVersionsForCloseOutStatement = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCloseOutStatement.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("closeOutStatement"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "duedate": + var allowedVersionsForDueDate = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDueDate.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("dueDate"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ActionItem"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ActionItem actionItem) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ActionItem", nameof(thing)); } - var actionItem = thing as ActionItem; - if (actionItem == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ActionItem since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ActionItem."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.1.0"); + writer.WritePropertyName("actionee"u8); + writer.WriteStringValue(actionItem.Actionee); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) + { + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.2.0"); + writer.WritePropertyName("actionee"u8); + writer.WriteStringValue(actionItem.Actionee); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) + { + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actionItem.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.3.0"); + writer.WritePropertyName("actionee"u8); + writer.WriteStringValue(actionItem.Actionee); + writer.WritePropertyName("actor"u8); + + if(actionItem.Actor.HasValue) + { + writer.WriteStringValue(actionItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) + { + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actionItem.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(actionItem); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs index 7235e1abc..c7484c138 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ActualFiniteStateList = CDP4Common.DTO.ActualFiniteStateList; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,566 @@ namespace CDP4JsonSerializer public class ActualFiniteStateListSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "actualState", actualState => new JArray(actualState) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "excludeOption", excludeOption => new JArray(excludeOption) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "possibleFiniteStateList", possibleFiniteStateList => new JArray(((IEnumerable)possibleFiniteStateList).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ActualFiniteStateList actualFiniteStateList) - { - var jsonObject = new JObject(); - jsonObject.Add("actualState", this.PropertySerializerMap["actualState"](actualFiniteStateList.ActualState.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), actualFiniteStateList.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](actualFiniteStateList.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludeOption", this.PropertySerializerMap["excludeOption"](actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](actualFiniteStateList.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](actualFiniteStateList.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](actualFiniteStateList.Owner)); - jsonObject.Add("possibleFiniteStateList", this.PropertySerializerMap["possibleFiniteStateList"](actualFiniteStateList.PossibleFiniteStateList.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](actualFiniteStateList.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](actualFiniteStateList.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualstate": + var allowedVersionsForActualState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualState.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("actualState"u8); + + if(value is IEnumerable objectListActualState) + { + foreach(var actualStateItem in objectListActualState.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeoption": + var allowedVersionsForExcludeOption = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludeOption.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludeOption"u8); + + if(value is IEnumerable objectListExcludeOption) + { + foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblefinitestatelist": + var allowedVersionsForPossibleFiniteStateList = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleFiniteStateList.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleFiniteStateList"u8); + + if(value is IEnumerable objectListPossibleFiniteStateList) + { + foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ActualFiniteStateList"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ActualFiniteStateList actualFiniteStateList) + { + throw new ArgumentException("The thing shall be a ActualFiniteStateList", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ActualFiniteStateList since Version is below 1.0.0"); + return; } - var actualFiniteStateList = thing as ActualFiniteStateList; - if (actualFiniteStateList == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ActualFiniteStateList."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.0.0"); + writer.WriteStartArray("actualState"u8); + + foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteStateList.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actualFiniteStateList.Owner); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in actualFiniteStateList.PossibleFiniteStateList.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.1.0"); + writer.WriteStartArray("actualState"u8); + + foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actualFiniteStateList.Owner); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in actualFiniteStateList.PossibleFiniteStateList.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.2.0"); + writer.WriteStartArray("actualState"u8); + + foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actualFiniteStateList.Owner); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in actualFiniteStateList.PossibleFiniteStateList.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteStateList.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(actualFiniteStateList.Actor.HasValue) + { + writer.WriteStringValue(actualFiniteStateList.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("actualState"u8); + + foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actualFiniteStateList.Owner); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in actualFiniteStateList.PossibleFiniteStateList.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteStateList.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(actualFiniteStateList); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs index 69ada2f4a..0f93c24da 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ActualFiniteState = CDP4Common.DTO.ActualFiniteState; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,450 @@ namespace CDP4JsonSerializer public class ActualFiniteStateSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "kind", kind => new JValue(kind.ToString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "possibleState", possibleState => new JArray(possibleState) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ActualFiniteState actualFiniteState) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), actualFiniteState.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](actualFiniteState.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](actualFiniteState.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](actualFiniteState.Iid)); - jsonObject.Add("kind", this.PropertySerializerMap["kind"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.ActualFiniteStateKind), actualFiniteState.Kind))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](actualFiniteState.ModifiedOn)); - jsonObject.Add("possibleState", this.PropertySerializerMap["possibleState"](actualFiniteState.PossibleState.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](actualFiniteState.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](actualFiniteState.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "kind": + var allowedVersionsForKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("kind"u8); + + if(value != null) + { + writer.WriteStringValue(((ActualFiniteStateKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblestate": + var allowedVersionsForPossibleState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleState.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleState"u8); + + if(value is IEnumerable objectListPossibleState) + { + foreach(var possibleStateItem in objectListPossibleState.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ActualFiniteState"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ActualFiniteState actualFiniteState) + { + throw new ArgumentException("The thing shall be a ActualFiniteState", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ActualFiniteState since Version is below 1.0.0"); + return; } - var actualFiniteState = thing as ActualFiniteState; - if (actualFiniteState == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ActualFiniteState."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteState.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(actualFiniteState.Actor.HasValue) + { + writer.WriteStringValue(actualFiniteState.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteState.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(actualFiniteState); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs index 62d8384d8..250910dbe 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Alias = CDP4Common.DTO.Alias; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class AliasSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isSynonym", isSynonym => new JValue(isSynonym) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Alias alias) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), alias.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](alias.Content)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](alias.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](alias.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](alias.Iid)); - jsonObject.Add("isSynonym", this.PropertySerializerMap["isSynonym"](alias.IsSynonym)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](alias.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](alias.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](alias.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](alias.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "issynonym": + var allowedVersionsForIsSynonym = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsSynonym.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isSynonym"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Alias"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Alias alias) + { + throw new ArgumentException("The thing shall be a Alias", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Alias since Version is below 1.0.0"); + return; } - var alias = thing as Alias; - if (alias == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Alias."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(alias.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(alias.Actor.HasValue) + { + writer.WriteStringValue(alias.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(alias.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(alias); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs index 9d3fdf76d..6b7bbe8aa 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using AndExpression = CDP4Common.DTO.AndExpression; /// /// The purpose of the class is to provide a specific serializer @@ -44,67 +50,416 @@ namespace CDP4JsonSerializer public class AndExpressionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "term", term => new JArray(term) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(AndExpression andExpression) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), andExpression.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](andExpression.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](andExpression.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](andExpression.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](andExpression.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](andExpression.RevisionNumber)); - jsonObject.Add("term", this.PropertySerializerMap["term"](andExpression.Term.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](andExpression.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "term": + var allowedVersionsForTerm = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTerm.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("term"u8); + + if(value is IEnumerable objectListTerm) + { + foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the AndExpression"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not AndExpression andExpression) + { + throw new ArgumentException("The thing shall be a AndExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of AndExpression since Version is below 1.0.0"); + return; } - var andExpression = thing as AndExpression; - if (andExpression == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a AndExpression."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(andExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(andExpression.Actor.HasValue) + { + writer.WriteStringValue(andExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(andExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(andExpression); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs index 6520bdeb1..39477bf3f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Approval = CDP4Common.DTO.Approval; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,532 @@ namespace CDP4JsonSerializer public class ApprovalSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Approval approval) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](approval.Author)); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationApprovalKind), approval.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), approval.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](approval.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](approval.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](approval.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](approval.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](approval.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](approval.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](approval.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](approval.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](approval.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](approval.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationApprovalKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Approval"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Approval approval) + { + throw new ArgumentException("The thing shall be a Approval", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Approval since Version is below 1.1.0"); + return; } - var approval = thing as Approval; - if (approval == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Approval."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(approval.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(approval.Actor.HasValue) + { + writer.WriteStringValue(approval.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(approval.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(approval); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs index 6d2c6992d..ee7e3e433 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ArrayParameterType = CDP4Common.DTO.ArrayParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,89 +50,910 @@ namespace CDP4JsonSerializer public class ArrayParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "component", component => new JArray(((IEnumerable)component).Cast().Select(x => x.ToJsonObject())) }, - { "definition", definition => new JArray(definition) }, - { "dimension", dimension => new JArray(((IEnumerable)dimension).Cast().Select(x => x.ToJsonObject())) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isFinalized", isFinalized => new JValue(isFinalized) }, - { "isTensor", isTensor => new JValue(isTensor) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ArrayParameterType arrayParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](arrayParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](arrayParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), arrayParameterType.ClassKind))); - jsonObject.Add("component", this.PropertySerializerMap["component"](arrayParameterType.Component.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](arrayParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("dimension", this.PropertySerializerMap["dimension"](arrayParameterType.Dimension.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](arrayParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](arrayParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](arrayParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](arrayParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](arrayParameterType.IsDeprecated)); - jsonObject.Add("isFinalized", this.PropertySerializerMap["isFinalized"](arrayParameterType.IsFinalized)); - jsonObject.Add("isTensor", this.PropertySerializerMap["isTensor"](arrayParameterType.IsTensor)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](arrayParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](arrayParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](arrayParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](arrayParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](arrayParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](arrayParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "component": + var allowedVersionsForComponent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForComponent.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("component"u8); + + if(value is IEnumerable objectListComponent) + { + foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "dimension": + var allowedVersionsForDimension = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDimension.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("dimension"u8); + + if(value is IEnumerable objectListDimension) + { + foreach(var dimensionItem in objectListDimension.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isfinalized": + var allowedVersionsForIsFinalized = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsFinalized.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isFinalized"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "istensor": + var allowedVersionsForIsTensor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsTensor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isTensor"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ArrayParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ArrayParameterType arrayParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ArrayParameterType", nameof(thing)); } - var arrayParameterType = thing as ArrayParameterType; - if (arrayParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ArrayParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ArrayParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("dimension"u8); + + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("dimension"u8); + + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("dimension"u8); + + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(arrayParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(arrayParameterType.Actor.HasValue) + { + writer.WriteStringValue(arrayParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("dimension"u8); + + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(arrayParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(arrayParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs index 82178452c..d908fa88d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using BinaryNote = CDP4Common.DTO.BinaryNote; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,581 @@ namespace CDP4JsonSerializer public class BinaryNoteSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "caption", caption => new JValue(caption) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fileType", fileType => new JValue(fileType) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(BinaryNote binaryNote) - { - var jsonObject = new JObject(); - jsonObject.Add("caption", this.PropertySerializerMap["caption"](binaryNote.Caption)); - jsonObject.Add("category", this.PropertySerializerMap["category"](binaryNote.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), binaryNote.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](binaryNote.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](binaryNote.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](binaryNote.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fileType", this.PropertySerializerMap["fileType"](binaryNote.FileType)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](binaryNote.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](binaryNote.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](binaryNote.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](binaryNote.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](binaryNote.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](binaryNote.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](binaryNote.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "caption": + var allowedVersionsForCaption = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCaption.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("caption"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filetype": + var allowedVersionsForFileType = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFileType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fileType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the BinaryNote"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not BinaryNote binaryNote) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a BinaryNote", nameof(thing)); } - var binaryNote = thing as BinaryNote; - if (binaryNote == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a BinaryNote."); + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.1.0"); + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.2.0"); + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryNote.Actor.HasValue) + { + writer.WriteStringValue(binaryNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(binaryNote); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs index 48b34af1c..68c5bc3ee 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using BinaryRelationshipRule = CDP4Common.DTO.BinaryRelationshipRule; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,804 @@ namespace CDP4JsonSerializer public class BinaryRelationshipRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "forwardRelationshipName", forwardRelationshipName => new JValue(forwardRelationshipName) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "inverseRelationshipName", inverseRelationshipName => new JValue(inverseRelationshipName) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "relationshipCategory", relationshipCategory => new JValue(relationshipCategory) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceCategory", sourceCategory => new JValue(sourceCategory) }, - { "targetCategory", targetCategory => new JValue(targetCategory) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(BinaryRelationshipRule binaryRelationshipRule) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](binaryRelationshipRule.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), binaryRelationshipRule.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](binaryRelationshipRule.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("forwardRelationshipName", this.PropertySerializerMap["forwardRelationshipName"](binaryRelationshipRule.ForwardRelationshipName)); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](binaryRelationshipRule.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](binaryRelationshipRule.Iid)); - jsonObject.Add("inverseRelationshipName", this.PropertySerializerMap["inverseRelationshipName"](binaryRelationshipRule.InverseRelationshipName)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](binaryRelationshipRule.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](binaryRelationshipRule.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](binaryRelationshipRule.Name)); - jsonObject.Add("relationshipCategory", this.PropertySerializerMap["relationshipCategory"](binaryRelationshipRule.RelationshipCategory)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](binaryRelationshipRule.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](binaryRelationshipRule.ShortName)); - jsonObject.Add("sourceCategory", this.PropertySerializerMap["sourceCategory"](binaryRelationshipRule.SourceCategory)); - jsonObject.Add("targetCategory", this.PropertySerializerMap["targetCategory"](binaryRelationshipRule.TargetCategory)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](binaryRelationshipRule.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "forwardrelationshipname": + var allowedVersionsForForwardRelationshipName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForForwardRelationshipName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("forwardRelationshipName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "inverserelationshipname": + var allowedVersionsForInverseRelationshipName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForInverseRelationshipName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("inverseRelationshipName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relationshipcategory": + var allowedVersionsForRelationshipCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelationshipCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("relationshipCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourcecategory": + var allowedVersionsForSourceCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sourceCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "targetcategory": + var allowedVersionsForTargetCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTargetCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("targetCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the BinaryRelationshipRule"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not BinaryRelationshipRule binaryRelationshipRule) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a BinaryRelationshipRule", nameof(thing)); } - var binaryRelationshipRule = thing as BinaryRelationshipRule; - if (binaryRelationshipRule == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a BinaryRelationshipRule."); + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationshipRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationshipRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryRelationshipRule.Actor.HasValue) + { + writer.WriteStringValue(binaryRelationshipRule.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationshipRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(binaryRelationshipRule); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs index 8537e6a20..f7c686f76 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using BinaryRelationship = CDP4Common.DTO.BinaryRelationship; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,595 @@ namespace CDP4JsonSerializer public class BinaryRelationshipSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterValue", parameterValue => new JArray(parameterValue) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "source", source => new JValue(source) }, - { "target", target => new JValue(target) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(BinaryRelationship binaryRelationship) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](binaryRelationship.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), binaryRelationship.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](binaryRelationship.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](binaryRelationship.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](binaryRelationship.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](binaryRelationship.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](binaryRelationship.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](binaryRelationship.Owner)); - jsonObject.Add("parameterValue", this.PropertySerializerMap["parameterValue"](binaryRelationship.ParameterValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](binaryRelationship.RevisionNumber)); - jsonObject.Add("source", this.PropertySerializerMap["source"](binaryRelationship.Source)); - jsonObject.Add("target", this.PropertySerializerMap["target"](binaryRelationship.Target)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](binaryRelationship.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalue": + var allowedVersionsForParameterValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "source": + var allowedVersionsForSource = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSource.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("source"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "target": + var allowedVersionsForTarget = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTarget.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("target"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the BinaryRelationship"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not BinaryRelationship binaryRelationship) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a BinaryRelationship", nameof(thing)); } - var binaryRelationship = thing as BinaryRelationship; - if (binaryRelationship == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a BinaryRelationship."); + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationship since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.0.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationship.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryRelationship.Actor.HasValue) + { + writer.WriteStringValue(binaryRelationship.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationship.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(binaryRelationship); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs index 80886dca3..55e95e544 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Book = CDP4Common.DTO.Book; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,568 @@ namespace CDP4JsonSerializer public class BookSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "section", section => new JArray(((IEnumerable)section).Cast().Select(x => x.ToJsonObject())) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Book book) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](book.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), book.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](book.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](book.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](book.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](book.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](book.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](book.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](book.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](book.RevisionNumber)); - jsonObject.Add("section", this.PropertySerializerMap["section"](book.Section.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](book.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](book.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "section": + var allowedVersionsForSection = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSection.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("section"u8); + + if(value is IEnumerable objectListSection) + { + foreach(var sectionItem in objectListSection.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + } + + writer.WriteEndArray(); + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Book"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Book book) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Book", nameof(thing)); } - var book = thing as Book; - if (book == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a Book."); + Logger.Log(LogLevel.Info, "Skipping serialization of Book since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(book.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(book.Actor.HasValue) + { + writer.WriteStringValue(book.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(book.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(book); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs index b712a5726..8bd6e5c00 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using BooleanParameterType = CDP4Common.DTO.BooleanParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class BooleanParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(BooleanParameterType booleanParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](booleanParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](booleanParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), booleanParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](booleanParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](booleanParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](booleanParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](booleanParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](booleanParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](booleanParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](booleanParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](booleanParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](booleanParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](booleanParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](booleanParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](booleanParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the BooleanParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not BooleanParameterType booleanParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a BooleanParameterType", nameof(thing)); } - var booleanParameterType = thing as BooleanParameterType; - if (booleanParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of BooleanParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a BooleanParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(booleanParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(booleanParameterType.Actor.HasValue) + { + writer.WriteStringValue(booleanParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(booleanParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(booleanParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs index 119b72d7d..f7d66e3c9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Bounds = CDP4Common.DTO.Bounds; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,501 @@ namespace CDP4JsonSerializer public class BoundsSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "height", height => new JValue(height) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "width", width => new JValue(width) }, - { "x", x => new JValue(x) }, - { "y", y => new JValue(y) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Bounds bounds) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), bounds.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](bounds.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](bounds.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("height", this.PropertySerializerMap["height"](bounds.Height)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](bounds.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](bounds.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](bounds.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](bounds.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](bounds.ThingPreference)); - jsonObject.Add("width", this.PropertySerializerMap["width"](bounds.Width)); - jsonObject.Add("x", this.PropertySerializerMap["x"](bounds.X)); - jsonObject.Add("y", this.PropertySerializerMap["y"](bounds.Y)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "height": + var allowedVersionsForHeight = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHeight.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("height"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "width": + var allowedVersionsForWidth = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForWidth.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("width"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "x": + var allowedVersionsForX = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForX.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("x"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "y": + var allowedVersionsForY = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForY.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("y"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Bounds"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Bounds bounds) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Bounds", nameof(thing)); } - var bounds = thing as Bounds; - if (bounds == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a Bounds."); + Logger.Log(LogLevel.Info, "Skipping serialization of Bounds since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(bounds.ThingPreference); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(bounds.Actor.HasValue) + { + writer.WriteStringValue(bounds.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(bounds.ThingPreference); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(bounds); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs index 4ba1f9927..bbcf92878 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using BuiltInRuleVerification = CDP4Common.DTO.BuiltInRuleVerification; /// /// The purpose of the class is to provide a specific serializer @@ -44,74 +50,588 @@ namespace CDP4JsonSerializer public class BuiltInRuleVerificationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "executedOn", executedOn => new JValue(executedOn != null ? ((DateTime)executedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ") : null) }, - { "iid", iid => new JValue(iid) }, - { "isActive", isActive => new JValue(isActive) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "violation", violation => new JArray(violation) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(BuiltInRuleVerification builtInRuleVerification) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), builtInRuleVerification.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("executedOn", this.PropertySerializerMap["executedOn"](builtInRuleVerification.ExecutedOn)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](builtInRuleVerification.Iid)); - jsonObject.Add("isActive", this.PropertySerializerMap["isActive"](builtInRuleVerification.IsActive)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](builtInRuleVerification.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](builtInRuleVerification.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](builtInRuleVerification.RevisionNumber)); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.RuleVerificationStatusKind), builtInRuleVerification.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](builtInRuleVerification.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "executedon": + var allowedVersionsForExecutedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExecutedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("executedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isactive": + var allowedVersionsForIsActive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsActive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isActive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((RuleVerificationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "violation": + var allowedVersionsForViolation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForViolation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("violation"u8); + + if(value is IEnumerable objectListViolation) + { + foreach(var violationItem in objectListViolation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the BuiltInRuleVerification"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not BuiltInRuleVerification builtInRuleVerification) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a BuiltInRuleVerification", nameof(thing)); } - var builtInRuleVerification = thing as BuiltInRuleVerification; - if (builtInRuleVerification == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of BuiltInRuleVerification since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a BuiltInRuleVerification."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(builtInRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(builtInRuleVerification.Actor.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(builtInRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(builtInRuleVerification); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs index 18a344b24..65054c330 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Category = CDP4Common.DTO.Category; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,784 @@ namespace CDP4JsonSerializer public class CategorySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isAbstract", isAbstract => new JValue(isAbstract) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "permissibleClass", permissibleClass => new JArray(permissibleClass) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "superCategory", superCategory => new JArray(superCategory) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Category category) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](category.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), category.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](category.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](category.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](category.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](category.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](category.Iid)); - jsonObject.Add("isAbstract", this.PropertySerializerMap["isAbstract"](category.IsAbstract)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](category.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](category.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](category.Name)); - jsonObject.Add("permissibleClass", this.PropertySerializerMap["permissibleClass"](category.PermissibleClass.Select(e => Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), e)))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](category.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](category.ShortName)); - jsonObject.Add("superCategory", this.PropertySerializerMap["superCategory"](category.SuperCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](category.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isabstract": + var allowedVersionsForIsAbstract = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsAbstract.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isAbstract"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "permissibleclass": + var allowedVersionsForPermissibleClass = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPermissibleClass.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("permissibleClass"u8); + + if(value is IEnumerable objectListPermissibleClass) + { + foreach(var permissibleClassItem in objectListPermissibleClass) + { + writer.WriteStringValue(((ClassKind)permissibleClassItem).ToString()); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "supercategory": + var allowedVersionsForSuperCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSuperCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("superCategory"u8); + + if(value is IEnumerable objectListSuperCategory) + { + foreach(var superCategoryItem in objectListSuperCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Category"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Category category) + { + throw new ArgumentException("The thing shall be a Category", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Category since Version is below 1.0.0"); + return; } - var category = thing as Category; - if (category == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Category."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); + + foreach(var permissibleClassItem in category.PermissibleClass) + { + writer.WriteStringValue(permissibleClassItem.ToString()); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); + + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); + + foreach(var permissibleClassItem in category.PermissibleClass) + { + writer.WriteStringValue(permissibleClassItem.ToString()); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); + + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); + + foreach(var permissibleClassItem in category.PermissibleClass) + { + writer.WriteStringValue(permissibleClassItem.ToString()); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); + + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(category.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(category.Actor.HasValue) + { + writer.WriteStringValue(category.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); + + foreach(var permissibleClassItem in category.PermissibleClass) + { + writer.WriteStringValue(permissibleClassItem.ToString()); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); + + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(category.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(category); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs index 8d3f40220..eaa2878c0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ChangeProposal = CDP4Common.DTO.ChangeProposal; /// /// The purpose of the class is to provide a specific serializer @@ -44,97 +50,959 @@ namespace CDP4JsonSerializer public class ChangeProposalSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "changeRequest", changeRequest => new JValue(changeRequest) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ChangeProposal changeProposal) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](changeProposal.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](changeProposal.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](changeProposal.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("changeRequest", this.PropertySerializerMap["changeRequest"](changeProposal.ChangeRequest)); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), changeProposal.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), changeProposal.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](changeProposal.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](changeProposal.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](changeProposal.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](changeProposal.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](changeProposal.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](changeProposal.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](changeProposal.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](changeProposal.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](changeProposal.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](changeProposal.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](changeProposal.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](changeProposal.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](changeProposal.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](changeProposal.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), changeProposal.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](changeProposal.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](changeProposal.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "changerequest": + var allowedVersionsForChangeRequest = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForChangeRequest.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("changeRequest"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeProposal"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ChangeProposal changeProposal) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ChangeProposal", nameof(thing)); } - var changeProposal = thing as ChangeProposal; - if (changeProposal == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ChangeProposal since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ChangeProposal."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeProposal.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeProposal.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeProposal.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(changeProposal.Actor.HasValue) + { + writer.WriteStringValue(changeProposal.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeProposal.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeProposal.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(changeProposal); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs index 9f66f39ba..2a227e46e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ChangeRequest = CDP4Common.DTO.ChangeRequest; /// /// The purpose of the class is to provide a specific serializer @@ -44,95 +50,928 @@ namespace CDP4JsonSerializer public class ChangeRequestSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ChangeRequest changeRequest) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](changeRequest.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](changeRequest.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](changeRequest.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), changeRequest.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), changeRequest.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](changeRequest.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](changeRequest.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](changeRequest.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](changeRequest.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](changeRequest.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](changeRequest.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](changeRequest.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](changeRequest.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](changeRequest.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](changeRequest.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](changeRequest.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](changeRequest.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](changeRequest.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](changeRequest.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), changeRequest.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](changeRequest.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](changeRequest.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeRequest"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ChangeRequest changeRequest) + { + throw new ArgumentException("The thing shall be a ChangeRequest", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ChangeRequest since Version is below 1.1.0"); + return; } - var changeRequest = thing as ChangeRequest; - if (changeRequest == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ChangeRequest."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeRequest.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeRequest.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeRequest.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(changeRequest.Actor.HasValue) + { + writer.WriteStringValue(changeRequest.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeRequest.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeRequest.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(changeRequest); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs index e4c65cfad..51f47dc83 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Citation = CDP4Common.DTO.Citation; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,528 @@ namespace CDP4JsonSerializer public class CitationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isAdaptation", isAdaptation => new JValue(isAdaptation) }, - { "location", location => new JValue(location) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "remark", remark => new JValue(remark) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "source", source => new JValue(source) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Citation citation) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), citation.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](citation.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](citation.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](citation.Iid)); - jsonObject.Add("isAdaptation", this.PropertySerializerMap["isAdaptation"](citation.IsAdaptation)); - jsonObject.Add("location", this.PropertySerializerMap["location"](citation.Location)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](citation.ModifiedOn)); - jsonObject.Add("remark", this.PropertySerializerMap["remark"](citation.Remark)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](citation.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](citation.ShortName)); - jsonObject.Add("source", this.PropertySerializerMap["source"](citation.Source)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](citation.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isadaptation": + var allowedVersionsForIsAdaptation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsAdaptation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isAdaptation"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "location": + var allowedVersionsForLocation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLocation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("location"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "remark": + var allowedVersionsForRemark = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRemark.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("remark"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "source": + var allowedVersionsForSource = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSource.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("source"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Citation"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Citation citation) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Citation", nameof(thing)); } - var citation = thing as Citation; - if (citation == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a Citation."); + Logger.Log(LogLevel.Info, "Skipping serialization of Citation since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(citation.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(citation.Actor.HasValue) + { + writer.WriteStringValue(citation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(citation.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(citation); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs index a9057cd4d..6d9c521f6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Color = CDP4Common.DTO.Color; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,494 @@ namespace CDP4JsonSerializer public class ColorSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "blue", blue => new JValue(blue) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "green", green => new JValue(green) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "red", red => new JValue(red) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Color color) - { - var jsonObject = new JObject(); - jsonObject.Add("blue", this.PropertySerializerMap["blue"](color.Blue)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), color.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](color.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](color.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("green", this.PropertySerializerMap["green"](color.Green)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](color.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](color.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](color.Name)); - jsonObject.Add("red", this.PropertySerializerMap["red"](color.Red)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](color.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](color.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "blue": + var allowedVersionsForBlue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBlue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("blue"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "green": + var allowedVersionsForGreen = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGreen.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("green"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "red": + var allowedVersionsForRed = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRed.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("red"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Color"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Color color) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Color", nameof(thing)); } - var color = thing as Color; - if (color == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a Color."); + Logger.Log(LogLevel.Info, "Skipping serialization of Color since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.0.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.1.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.2.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(color.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(color.Actor.HasValue) + { + writer.WriteStringValue(color.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(color.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(color); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs index e38b7bd00..a5f4403a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using CommonFileStore = CDP4Common.DTO.CommonFileStore; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,576 @@ namespace CDP4JsonSerializer public class CommonFileStoreSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "file", file => new JArray(file) }, - { "folder", folder => new JArray(folder) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(CommonFileStore commonFileStore) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), commonFileStore.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](commonFileStore.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](commonFileStore.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](commonFileStore.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("file", this.PropertySerializerMap["file"](commonFileStore.File.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("folder", this.PropertySerializerMap["folder"](commonFileStore.Folder.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](commonFileStore.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](commonFileStore.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](commonFileStore.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](commonFileStore.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](commonFileStore.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](commonFileStore.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "file": + var allowedVersionsForFile = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFile.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("file"u8); + + if(value is IEnumerable objectListFile) + { + foreach(var fileItem in objectListFile.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + } + + writer.WriteEndArray(); + break; + case "folder": + var allowedVersionsForFolder = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFolder.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("folder"u8); + + if(value is IEnumerable objectListFolder) + { + foreach(var folderItem in objectListFolder.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the CommonFileStore"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not CommonFileStore commonFileStore) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a CommonFileStore", nameof(thing)); } - var commonFileStore = thing as CommonFileStore; - if (commonFileStore == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of CommonFileStore since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a CommonFileStore."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(commonFileStore.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(commonFileStore.Actor.HasValue) + { + writer.WriteStringValue(commonFileStore.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(commonFileStore.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(commonFileStore); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs index 16358243c..7ab792415 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using CompoundParameterType = CDP4Common.DTO.CompoundParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,818 @@ namespace CDP4JsonSerializer public class CompoundParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "component", component => new JArray(((IEnumerable)component).Cast().Select(x => x.ToJsonObject())) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isFinalized", isFinalized => new JValue(isFinalized) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(CompoundParameterType compoundParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](compoundParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](compoundParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), compoundParameterType.ClassKind))); - jsonObject.Add("component", this.PropertySerializerMap["component"](compoundParameterType.Component.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](compoundParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](compoundParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](compoundParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](compoundParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](compoundParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](compoundParameterType.IsDeprecated)); - jsonObject.Add("isFinalized", this.PropertySerializerMap["isFinalized"](compoundParameterType.IsFinalized)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](compoundParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](compoundParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](compoundParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](compoundParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](compoundParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](compoundParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "component": + var allowedVersionsForComponent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForComponent.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("component"u8); + + if(value is IEnumerable objectListComponent) + { + foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isfinalized": + var allowedVersionsForIsFinalized = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsFinalized.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isFinalized"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the CompoundParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not CompoundParameterType compoundParameterType) + { + throw new ArgumentException("The thing shall be a CompoundParameterType", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of CompoundParameterType since Version is below 1.0.0"); + return; } - var compoundParameterType = thing as CompoundParameterType; - if (compoundParameterType == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a CompoundParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(compoundParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(compoundParameterType.Actor.HasValue) + { + writer.WriteStringValue(compoundParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(compoundParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(compoundParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs index ceb9b8beb..6e2f969cc 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Constant = CDP4Common.DTO.Constant; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,816 @@ namespace CDP4JsonSerializer public class ConstantSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(((ValueArray)value).ToJsonString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Constant constant) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](constant.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](constant.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), constant.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](constant.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](constant.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](constant.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](constant.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](constant.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](constant.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](constant.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](constant.Name)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](constant.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](constant.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](constant.Scale)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](constant.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](constant.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](constant.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Constant"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Constant constant) + { + throw new ArgumentException("The thing shall be a Constant", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Constant since Version is below 1.0.0"); + return; } - var constant = thing as Constant; - if (constant == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Constant."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) + { + writer.WriteStringValue(constant.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WriteString("value"u8, constant.Value.ToJsonString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) + { + writer.WriteStringValue(constant.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WriteString("value"u8, constant.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) + { + writer.WriteStringValue(constant.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(constant.ThingPreference); + writer.WriteString("value"u8, constant.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(constant.Actor.HasValue) + { + writer.WriteStringValue(constant.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) + { + writer.WriteStringValue(constant.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(constant.ThingPreference); + writer.WriteString("value"u8, constant.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(constant); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs index 958eeb39f..494f45e35 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ContractChangeNotice = CDP4Common.DTO.ContractChangeNotice; /// /// The purpose of the class is to provide a specific serializer @@ -44,97 +50,959 @@ namespace CDP4JsonSerializer public class ContractChangeNoticeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "changeProposal", changeProposal => new JValue(changeProposal) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ContractChangeNotice contractChangeNotice) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](contractChangeNotice.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](contractChangeNotice.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](contractChangeNotice.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("changeProposal", this.PropertySerializerMap["changeProposal"](contractChangeNotice.ChangeProposal)); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), contractChangeNotice.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), contractChangeNotice.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](contractChangeNotice.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](contractChangeNotice.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](contractChangeNotice.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](contractChangeNotice.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](contractChangeNotice.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](contractChangeNotice.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](contractChangeNotice.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](contractChangeNotice.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](contractChangeNotice.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](contractChangeNotice.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](contractChangeNotice.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), contractChangeNotice.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](contractChangeNotice.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](contractChangeNotice.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "changeproposal": + var allowedVersionsForChangeProposal = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForChangeProposal.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("changeProposal"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ContractChangeNotice"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ContractChangeNotice contractChangeNotice) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ContractChangeNotice", nameof(thing)); } - var contractChangeNotice = thing as ContractChangeNotice; - if (contractChangeNotice == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ContractChangeNotice since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ContractChangeNotice."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(contractChangeNotice.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(contractChangeNotice.Actor.HasValue) + { + writer.WriteStringValue(contractChangeNotice.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(contractChangeNotice.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(contractChangeNotice); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs index 5845ccd59..74aba1f5b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using CyclicRatioScale = CDP4Common.DTO.CyclicRatioScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,99 +50,1056 @@ namespace CDP4JsonSerializer public class CyclicRatioScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isMaximumInclusive", isMaximumInclusive => new JValue(isMaximumInclusive) }, - { "isMinimumInclusive", isMinimumInclusive => new JValue(isMinimumInclusive) }, - { "mappingToReferenceScale", mappingToReferenceScale => new JArray(mappingToReferenceScale) }, - { "maximumPermissibleValue", maximumPermissibleValue => new JValue(maximumPermissibleValue) }, - { "minimumPermissibleValue", minimumPermissibleValue => new JValue(minimumPermissibleValue) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "modulus", modulus => new JValue(modulus) }, - { "name", name => new JValue(name) }, - { "negativeValueConnotation", negativeValueConnotation => new JValue(negativeValueConnotation) }, - { "numberSet", numberSet => new JValue(numberSet.ToString()) }, - { "positiveValueConnotation", positiveValueConnotation => new JValue(positiveValueConnotation) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - { "valueDefinition", valueDefinition => new JArray(valueDefinition) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(CyclicRatioScale cyclicRatioScale) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](cyclicRatioScale.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), cyclicRatioScale.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](cyclicRatioScale.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](cyclicRatioScale.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](cyclicRatioScale.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](cyclicRatioScale.IsDeprecated)); - jsonObject.Add("isMaximumInclusive", this.PropertySerializerMap["isMaximumInclusive"](cyclicRatioScale.IsMaximumInclusive)); - jsonObject.Add("isMinimumInclusive", this.PropertySerializerMap["isMinimumInclusive"](cyclicRatioScale.IsMinimumInclusive)); - jsonObject.Add("mappingToReferenceScale", this.PropertySerializerMap["mappingToReferenceScale"](cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("maximumPermissibleValue", this.PropertySerializerMap["maximumPermissibleValue"](cyclicRatioScale.MaximumPermissibleValue)); - jsonObject.Add("minimumPermissibleValue", this.PropertySerializerMap["minimumPermissibleValue"](cyclicRatioScale.MinimumPermissibleValue)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](cyclicRatioScale.ModifiedOn)); - jsonObject.Add("modulus", this.PropertySerializerMap["modulus"](cyclicRatioScale.Modulus)); - jsonObject.Add("name", this.PropertySerializerMap["name"](cyclicRatioScale.Name)); - jsonObject.Add("negativeValueConnotation", this.PropertySerializerMap["negativeValueConnotation"](cyclicRatioScale.NegativeValueConnotation)); - jsonObject.Add("numberSet", this.PropertySerializerMap["numberSet"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.NumberSetKind), cyclicRatioScale.NumberSet))); - jsonObject.Add("positiveValueConnotation", this.PropertySerializerMap["positiveValueConnotation"](cyclicRatioScale.PositiveValueConnotation)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](cyclicRatioScale.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](cyclicRatioScale.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](cyclicRatioScale.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](cyclicRatioScale.Unit)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + var allowedVersionsForIsMaximumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + var allowedVersionsForIsMinimumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + var allowedVersionsForMappingToReferenceScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + var allowedVersionsForMaximumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minimumpermissiblevalue": + var allowedVersionsForMinimumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modulus": + var allowedVersionsForModulus = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModulus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modulus"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + var allowedVersionsForNegativeValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + var allowedVersionsForNumberSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + var allowedVersionsForPositiveValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the CyclicRatioScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not CyclicRatioScale cyclicRatioScale) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a CyclicRatioScale", nameof(thing)); } - var cyclicRatioScale = thing as CyclicRatioScale; - if (cyclicRatioScale == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a CyclicRatioScale."); + Logger.Log(LogLevel.Info, "Skipping serialization of CyclicRatioScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(cyclicRatioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(cyclicRatioScale.Actor.HasValue) + { + writer.WriteStringValue(cyclicRatioScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(cyclicRatioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(cyclicRatioScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs index 6059c3f82..9835c3d53 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DateParameterType = CDP4Common.DTO.DateParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class DateParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DateParameterType dateParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](dateParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](dateParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), dateParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](dateParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](dateParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](dateParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](dateParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](dateParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](dateParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](dateParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](dateParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](dateParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](dateParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](dateParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](dateParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DateParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DateParameterType dateParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DateParameterType", nameof(thing)); } - var dateParameterType = thing as DateParameterType; - if (dateParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DateParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DateParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(dateParameterType.Actor.HasValue) + { + writer.WriteStringValue(dateParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(dateParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs index 57d229dbb..403c97965 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DateTimeParameterType = CDP4Common.DTO.DateTimeParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class DateTimeParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DateTimeParameterType dateTimeParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](dateTimeParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](dateTimeParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), dateTimeParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](dateTimeParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](dateTimeParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](dateTimeParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](dateTimeParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](dateTimeParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](dateTimeParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](dateTimeParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](dateTimeParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](dateTimeParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](dateTimeParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DateTimeParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DateTimeParameterType dateTimeParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DateTimeParameterType", nameof(thing)); } - var dateTimeParameterType = thing as DateTimeParameterType; - if (dateTimeParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DateTimeParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DateTimeParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateTimeParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(dateTimeParameterType.Actor.HasValue) + { + writer.WriteStringValue(dateTimeParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateTimeParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(dateTimeParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs index 1feb01bf2..9f49314eb 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DecompositionRule = CDP4Common.DTO.DecompositionRule; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,830 @@ namespace CDP4JsonSerializer public class DecompositionRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "containedCategory", containedCategory => new JArray(containedCategory) }, - { "containingCategory", containingCategory => new JValue(containingCategory) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "maxContained", maxContained => new JValue(maxContained) }, - { "minContained", minContained => new JValue(minContained) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DecompositionRule decompositionRule) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](decompositionRule.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), decompositionRule.ClassKind))); - jsonObject.Add("containedCategory", this.PropertySerializerMap["containedCategory"](decompositionRule.ContainedCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("containingCategory", this.PropertySerializerMap["containingCategory"](decompositionRule.ContainingCategory)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](decompositionRule.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](decompositionRule.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](decompositionRule.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](decompositionRule.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](decompositionRule.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](decompositionRule.IsDeprecated)); - jsonObject.Add("maxContained", this.PropertySerializerMap["maxContained"](decompositionRule.MaxContained)); - jsonObject.Add("minContained", this.PropertySerializerMap["minContained"](decompositionRule.MinContained)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](decompositionRule.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](decompositionRule.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](decompositionRule.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](decompositionRule.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](decompositionRule.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "containedcategory": + var allowedVersionsForContainedCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainedCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("containedCategory"u8); + + if(value is IEnumerable objectListContainedCategory) + { + foreach(var containedCategoryItem in objectListContainedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "containingcategory": + var allowedVersionsForContainingCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainingCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("containingCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "maxcontained": + var allowedVersionsForMaxContained = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaxContained.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maxContained"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mincontained": + var allowedVersionsForMinContained = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinContained.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minContained"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DecompositionRule"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DecompositionRule decompositionRule) + { + throw new ArgumentException("The thing shall be a DecompositionRule", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of DecompositionRule since Version is below 1.0.0"); + return; } - var decompositionRule = thing as DecompositionRule; - if (decompositionRule == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DecompositionRule."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); + + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) + { + writer.WriteNumberValue(decompositionRule.MaxContained.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); + + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) + { + writer.WriteNumberValue(decompositionRule.MaxContained.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); + + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) + { + writer.WriteNumberValue(decompositionRule.MaxContained.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(decompositionRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(decompositionRule.Actor.HasValue) + { + writer.WriteStringValue(decompositionRule.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); + + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) + { + writer.WriteNumberValue(decompositionRule.MaxContained.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(decompositionRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(decompositionRule); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs index 5819cc33a..dd3899aae 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Definition = CDP4Common.DTO.Definition; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,600 @@ namespace CDP4JsonSerializer public class DefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "citation", citation => new JArray(citation) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "example", example => new JArray(((IEnumerable)example).Cast().Select(x => x.ToJsonObject())) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "note", note => new JArray(((IEnumerable)note).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Definition definition) - { - var jsonObject = new JObject(); - jsonObject.Add("citation", this.PropertySerializerMap["citation"](definition.Citation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), definition.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](definition.Content)); - jsonObject.Add("example", this.PropertySerializerMap["example"](definition.Example.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](definition.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](definition.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](definition.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](definition.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](definition.ModifiedOn)); - jsonObject.Add("note", this.PropertySerializerMap["note"](definition.Note.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](definition.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](definition.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "citation": + var allowedVersionsForCitation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCitation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("citation"u8); + + if(value is IEnumerable objectListCitation) + { + foreach(var citationItem in objectListCitation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "example": + var allowedVersionsForExample = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExample.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("example"u8); + + if(value is IEnumerable objectListExample) + { + foreach(var exampleItem in objectListExample.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "note": + var allowedVersionsForNote = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNote.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("note"u8); + + if(value is IEnumerable objectListNote) + { + foreach(var noteItem in objectListNote.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Definition"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Definition definition) + { + throw new ArgumentException("The thing shall be a Definition", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Definition since Version is below 1.0.0"); + return; } - var definition = thing as Definition; - if (definition == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Definition."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.0.0"); + writer.WriteStartArray("citation"u8); + + foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(definition.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(definition.Content); + writer.WriteStartArray("example"u8); + + foreach(var exampleItem in definition.Example.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(definition.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(definition.LanguageCode); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in definition.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(definition.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.1.0"); + writer.WriteStartArray("citation"u8); + + foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(definition.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(definition.Content); + writer.WriteStartArray("example"u8); + + foreach(var exampleItem in definition.Example.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(definition.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(definition.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(definition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in definition.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(definition.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.2.0"); + writer.WriteStartArray("citation"u8); + + foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(definition.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(definition.Content); + writer.WriteStartArray("example"u8); + + foreach(var exampleItem in definition.Example.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(definition.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(definition.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(definition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in definition.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(definition.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(definition.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(definition.Actor.HasValue) + { + writer.WriteStringValue(definition.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("citation"u8); + + foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(definition.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(definition.Content); + writer.WriteStartArray("example"u8); + + foreach(var exampleItem in definition.Example.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(definition.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(definition.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(definition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in definition.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(definition.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(definition.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(definition); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs index 5b0223c39..f3f69c568 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DependentParameterTypeAssignment = CDP4Common.DTO.DependentParameterTypeAssignment; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,390 @@ namespace CDP4JsonSerializer public class DependentParameterTypeAssignmentSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "measurementScale", measurementScale => new JValue(measurementScale) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DependentParameterTypeAssignment dependentParameterTypeAssignment) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), dependentParameterTypeAssignment.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](dependentParameterTypeAssignment.Iid)); - jsonObject.Add("measurementScale", this.PropertySerializerMap["measurementScale"](dependentParameterTypeAssignment.MeasurementScale)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](dependentParameterTypeAssignment.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](dependentParameterTypeAssignment.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](dependentParameterTypeAssignment.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](dependentParameterTypeAssignment.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "measurementscale": + var allowedVersionsForMeasurementScale = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMeasurementScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("measurementScale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DependentParameterTypeAssignment"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DependentParameterTypeAssignment dependentParameterTypeAssignment) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DependentParameterTypeAssignment", nameof(thing)); } - var dependentParameterTypeAssignment = thing as DependentParameterTypeAssignment; - if (dependentParameterTypeAssignment == null) + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DependentParameterTypeAssignment since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DependentParameterTypeAssignment."); + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DependentParameterTypeAssignment for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(dependentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DependentParameterTypeAssignment for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(dependentParameterTypeAssignment.Actor.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(dependentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(dependentParameterTypeAssignment); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs index cfd56cde5..1df35a4f6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DerivedQuantityKind = CDP4Common.DTO.DerivedQuantityKind; /// /// The purpose of the class is to provide a specific serializer @@ -44,89 +50,910 @@ namespace CDP4JsonSerializer public class DerivedQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultScale", defaultScale => new JValue(defaultScale) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "possibleScale", possibleScale => new JArray(possibleScale) }, - { "quantityDimensionSymbol", quantityDimensionSymbol => new JValue(quantityDimensionSymbol) }, - { "quantityKindFactor", quantityKindFactor => new JArray(((IEnumerable)quantityKindFactor).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DerivedQuantityKind derivedQuantityKind) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](derivedQuantityKind.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](derivedQuantityKind.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), derivedQuantityKind.ClassKind))); - jsonObject.Add("defaultScale", this.PropertySerializerMap["defaultScale"](derivedQuantityKind.DefaultScale)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](derivedQuantityKind.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](derivedQuantityKind.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](derivedQuantityKind.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](derivedQuantityKind.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](derivedQuantityKind.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](derivedQuantityKind.Name)); - jsonObject.Add("possibleScale", this.PropertySerializerMap["possibleScale"](derivedQuantityKind.PossibleScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("quantityDimensionSymbol", this.PropertySerializerMap["quantityDimensionSymbol"](derivedQuantityKind.QuantityDimensionSymbol)); - jsonObject.Add("quantityKindFactor", this.PropertySerializerMap["quantityKindFactor"](derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](derivedQuantityKind.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](derivedQuantityKind.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](derivedQuantityKind.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](derivedQuantityKind.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultscale": + var allowedVersionsForDefaultScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultScale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblescale": + var allowedVersionsForPossibleScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleScale"u8); + + if(value is IEnumerable objectListPossibleScale) + { + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "quantitydimensionsymbol": + var allowedVersionsForQuantityDimensionSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "quantitykindfactor": + var allowedVersionsForQuantityKindFactor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForQuantityKindFactor.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("quantityKindFactor"u8); + + if(value is IEnumerable objectListQuantityKindFactor) + { + foreach(var quantityKindFactorItem in objectListQuantityKindFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedQuantityKind"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DerivedQuantityKind derivedQuantityKind) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DerivedQuantityKind", nameof(thing)); } - var derivedQuantityKind = thing as DerivedQuantityKind; - if (derivedQuantityKind == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DerivedQuantityKind since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DerivedQuantityKind."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); + + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); + + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); + + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedQuantityKind.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(derivedQuantityKind.Actor.HasValue) + { + writer.WriteStringValue(derivedQuantityKind.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); + + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedQuantityKind.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(derivedQuantityKind); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs index ad8dea7a0..ecea0fcae 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DerivedUnit = CDP4Common.DTO.DerivedUnit; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class DerivedUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unitFactor", unitFactor => new JArray(((IEnumerable)unitFactor).Cast().Select(x => x.ToJsonObject())) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DerivedUnit derivedUnit) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](derivedUnit.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), derivedUnit.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](derivedUnit.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](derivedUnit.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](derivedUnit.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](derivedUnit.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](derivedUnit.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](derivedUnit.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](derivedUnit.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](derivedUnit.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](derivedUnit.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](derivedUnit.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](derivedUnit.ThingPreference)); - jsonObject.Add("unitFactor", this.PropertySerializerMap["unitFactor"](derivedUnit.UnitFactor.OrderBy(x => x, this.orderedItemComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unitfactor": + var allowedVersionsForUnitFactor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnitFactor.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("unitFactor"u8); + + if(value is IEnumerable objectListUnitFactor) + { + foreach(var unitFactorItem in objectListUnitFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedUnit"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DerivedUnit derivedUnit) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DerivedUnit", nameof(thing)); } - var derivedUnit = thing as DerivedUnit; - if (derivedUnit == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a DerivedUnit."); + Logger.Log(LogLevel.Info, "Skipping serialization of DerivedUnit since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WriteStartArray("unitFactor"u8); + + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WriteStartArray("unitFactor"u8); + + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedUnit.ThingPreference); + writer.WriteStartArray("unitFactor"u8); + + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(derivedUnit.Actor.HasValue) + { + writer.WriteStringValue(derivedUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedUnit.ThingPreference); + writer.WriteStartArray("unitFactor"u8); + + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(derivedUnit); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs index d9639848c..769a56402 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DiagramCanvas = CDP4Common.DTO.DiagramCanvas; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,506 @@ namespace CDP4JsonSerializer public class DiagramCanvasSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "bounds", bounds => new JArray(bounds) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "diagramElement", diagramElement => new JArray(diagramElement) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DiagramCanvas diagramCanvas) - { - var jsonObject = new JObject(); - jsonObject.Add("bounds", this.PropertySerializerMap["bounds"](diagramCanvas.Bounds)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), diagramCanvas.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](diagramCanvas.CreatedOn)); - jsonObject.Add("diagramElement", this.PropertySerializerMap["diagramElement"](diagramCanvas.DiagramElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](diagramCanvas.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](diagramCanvas.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](diagramCanvas.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](diagramCanvas.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](diagramCanvas.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](diagramCanvas.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](diagramCanvas.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "bounds": + var allowedVersionsForBounds = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBounds.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("bounds"u8); + + if(value is IEnumerable objectListBounds) + { + foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "diagramelement": + var allowedVersionsForDiagramElement = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("diagramElement"u8); + + if(value is IEnumerable objectListDiagramElement) + { + foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramCanvas"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DiagramCanvas diagramCanvas) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DiagramCanvas", nameof(thing)); } - var diagramCanvas = thing as DiagramCanvas; - if (diagramCanvas == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a DiagramCanvas."); + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramCanvas since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramCanvas.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(diagramCanvas.Actor.HasValue) + { + writer.WriteStringValue(diagramCanvas.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramCanvas.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(diagramCanvas); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs index 555bc86a6..54d41184c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DiagramEdge = CDP4Common.DTO.DiagramEdge; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,751 @@ namespace CDP4JsonSerializer public class DiagramEdgeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "bounds", bounds => new JArray(bounds) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "depictedThing", depictedThing => new JValue(depictedThing) }, - { "diagramElement", diagramElement => new JArray(diagramElement) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "localStyle", localStyle => new JArray(localStyle) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "point", point => new JArray(((IEnumerable)point).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "sharedStyle", sharedStyle => new JValue(sharedStyle) }, - { "source", source => new JValue(source) }, - { "target", target => new JValue(target) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DiagramEdge diagramEdge) - { - var jsonObject = new JObject(); - jsonObject.Add("bounds", this.PropertySerializerMap["bounds"](diagramEdge.Bounds)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), diagramEdge.ClassKind))); - jsonObject.Add("depictedThing", this.PropertySerializerMap["depictedThing"](diagramEdge.DepictedThing)); - jsonObject.Add("diagramElement", this.PropertySerializerMap["diagramElement"](diagramEdge.DiagramElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](diagramEdge.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](diagramEdge.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](diagramEdge.Iid)); - jsonObject.Add("localStyle", this.PropertySerializerMap["localStyle"](diagramEdge.LocalStyle)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](diagramEdge.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](diagramEdge.Name)); - jsonObject.Add("point", this.PropertySerializerMap["point"](diagramEdge.Point.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](diagramEdge.RevisionNumber)); - jsonObject.Add("sharedStyle", this.PropertySerializerMap["sharedStyle"](diagramEdge.SharedStyle)); - jsonObject.Add("source", this.PropertySerializerMap["source"](diagramEdge.Source)); - jsonObject.Add("target", this.PropertySerializerMap["target"](diagramEdge.Target)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](diagramEdge.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "bounds": + var allowedVersionsForBounds = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBounds.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("bounds"u8); + + if(value is IEnumerable objectListBounds) + { + foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "depictedthing": + var allowedVersionsForDepictedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDepictedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("depictedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "diagramelement": + var allowedVersionsForDiagramElement = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("diagramElement"u8); + + if(value is IEnumerable objectListDiagramElement) + { + foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "localstyle": + var allowedVersionsForLocalStyle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLocalStyle.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("localStyle"u8); + + if(value is IEnumerable objectListLocalStyle) + { + foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "point": + var allowedVersionsForPoint = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPoint.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("point"u8); + + if(value is IEnumerable objectListPoint) + { + foreach(var pointItem in objectListPoint.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pointItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sharedstyle": + var allowedVersionsForSharedStyle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSharedStyle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sharedStyle"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "source": + var allowedVersionsForSource = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSource.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("source"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "target": + var allowedVersionsForTarget = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTarget.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("target"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramEdge"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DiagramEdge diagramEdge) + { + throw new ArgumentException("The thing shall be a DiagramEdge", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramEdge since Version is below 1.1.0"); + return; } - var diagramEdge = thing as DiagramEdge; - if (diagramEdge == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a DiagramEdge."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramEdge.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramEdge.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); + + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pointItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramEdge.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramEdge.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramEdge.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); + + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pointItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramEdge.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramEdge.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(diagramEdge.Actor.HasValue) + { + writer.WriteStringValue(diagramEdge.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramEdge.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramEdge.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); + + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pointItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramEdge.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramEdge.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(diagramEdge); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs index d32672726..246cec687 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DiagramObject = CDP4Common.DTO.DiagramObject; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,702 @@ namespace CDP4JsonSerializer public class DiagramObjectSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "bounds", bounds => new JArray(bounds) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "depictedThing", depictedThing => new JValue(depictedThing) }, - { "diagramElement", diagramElement => new JArray(diagramElement) }, - { "documentation", documentation => new JValue(documentation) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "localStyle", localStyle => new JArray(localStyle) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "resolution", resolution => new JValue(resolution) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "sharedStyle", sharedStyle => new JValue(sharedStyle) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DiagramObject diagramObject) - { - var jsonObject = new JObject(); - jsonObject.Add("bounds", this.PropertySerializerMap["bounds"](diagramObject.Bounds)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), diagramObject.ClassKind))); - jsonObject.Add("depictedThing", this.PropertySerializerMap["depictedThing"](diagramObject.DepictedThing)); - jsonObject.Add("diagramElement", this.PropertySerializerMap["diagramElement"](diagramObject.DiagramElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("documentation", this.PropertySerializerMap["documentation"](diagramObject.Documentation)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](diagramObject.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](diagramObject.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](diagramObject.Iid)); - jsonObject.Add("localStyle", this.PropertySerializerMap["localStyle"](diagramObject.LocalStyle)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](diagramObject.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](diagramObject.Name)); - jsonObject.Add("resolution", this.PropertySerializerMap["resolution"](diagramObject.Resolution)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](diagramObject.RevisionNumber)); - jsonObject.Add("sharedStyle", this.PropertySerializerMap["sharedStyle"](diagramObject.SharedStyle)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](diagramObject.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "bounds": + var allowedVersionsForBounds = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBounds.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("bounds"u8); + + if(value is IEnumerable objectListBounds) + { + foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "depictedthing": + var allowedVersionsForDepictedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDepictedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("depictedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "diagramelement": + var allowedVersionsForDiagramElement = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("diagramElement"u8); + + if(value is IEnumerable objectListDiagramElement) + { + foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + } + + writer.WriteEndArray(); + break; + case "documentation": + var allowedVersionsForDocumentation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDocumentation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("documentation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "localstyle": + var allowedVersionsForLocalStyle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLocalStyle.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("localStyle"u8); + + if(value is IEnumerable objectListLocalStyle) + { + foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "resolution": + var allowedVersionsForResolution = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForResolution.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("resolution"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sharedstyle": + var allowedVersionsForSharedStyle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSharedStyle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sharedStyle"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramObject"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DiagramObject diagramObject) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DiagramObject", nameof(thing)); } - var diagramObject = thing as DiagramObject; - if (diagramObject == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a DiagramObject."); + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramObject since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramObject.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramObject.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramObject.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramObject.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramObject.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(diagramObject.Actor.HasValue) + { + writer.WriteStringValue(diagramObject.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) + { + writer.WriteStringValue(diagramObject.DepictedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) + { + writer.WriteStringValue(diagramObject.SharedStyle.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramObject.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(diagramObject); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs index ce77fca09..150af9e1c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DomainFileStore = CDP4Common.DTO.DomainFileStore; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,610 @@ namespace CDP4JsonSerializer public class DomainFileStoreSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "file", file => new JArray(file) }, - { "folder", folder => new JArray(folder) }, - { "iid", iid => new JValue(iid) }, - { "isHidden", isHidden => new JValue(isHidden) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DomainFileStore domainFileStore) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), domainFileStore.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](domainFileStore.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](domainFileStore.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](domainFileStore.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("file", this.PropertySerializerMap["file"](domainFileStore.File.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("folder", this.PropertySerializerMap["folder"](domainFileStore.Folder.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](domainFileStore.Iid)); - jsonObject.Add("isHidden", this.PropertySerializerMap["isHidden"](domainFileStore.IsHidden)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](domainFileStore.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](domainFileStore.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](domainFileStore.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](domainFileStore.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](domainFileStore.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "file": + var allowedVersionsForFile = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFile.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("file"u8); + + if(value is IEnumerable objectListFile) + { + foreach(var fileItem in objectListFile.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + } + + writer.WriteEndArray(); + break; + case "folder": + var allowedVersionsForFolder = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFolder.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("folder"u8); + + if(value is IEnumerable objectListFolder) + { + foreach(var folderItem in objectListFolder.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ishidden": + var allowedVersionsForIsHidden = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsHidden.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isHidden"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainFileStore"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DomainFileStore domainFileStore) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DomainFileStore", nameof(thing)); } - var domainFileStore = thing as DomainFileStore; - if (domainFileStore == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a DomainFileStore."); + Logger.Log(LogLevel.Info, "Skipping serialization of DomainFileStore since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainFileStore.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(domainFileStore.Actor.HasValue) + { + writer.WriteStringValue(domainFileStore.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainFileStore.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(domainFileStore); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs index b2198193c..39729d22c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DomainOfExpertiseGroup = CDP4Common.DTO.DomainOfExpertiseGroup; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class DomainOfExpertiseGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "domain", domain => new JArray(domain) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DomainOfExpertiseGroup domainOfExpertiseGroup) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](domainOfExpertiseGroup.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), domainOfExpertiseGroup.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](domainOfExpertiseGroup.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("domain", this.PropertySerializerMap["domain"](domainOfExpertiseGroup.Domain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](domainOfExpertiseGroup.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](domainOfExpertiseGroup.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](domainOfExpertiseGroup.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](domainOfExpertiseGroup.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](domainOfExpertiseGroup.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](domainOfExpertiseGroup.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](domainOfExpertiseGroup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "domain": + var allowedVersionsForDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domain"u8); + + if(value is IEnumerable objectListDomain) + { + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertiseGroup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DomainOfExpertiseGroup domainOfExpertiseGroup) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DomainOfExpertiseGroup", nameof(thing)); } - var domainOfExpertiseGroup = thing as DomainOfExpertiseGroup; - if (domainOfExpertiseGroup == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a DomainOfExpertiseGroup."); + Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertiseGroup since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(domainOfExpertiseGroup.Actor.HasValue) + { + writer.WriteStringValue(domainOfExpertiseGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(domainOfExpertiseGroup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs index 5054e25b6..d5fe53e4e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using DomainOfExpertise = CDP4Common.DTO.DomainOfExpertise; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class DomainOfExpertiseSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(DomainOfExpertise domainOfExpertise) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](domainOfExpertise.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](domainOfExpertise.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), domainOfExpertise.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](domainOfExpertise.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](domainOfExpertise.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](domainOfExpertise.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](domainOfExpertise.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](domainOfExpertise.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](domainOfExpertise.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](domainOfExpertise.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](domainOfExpertise.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](domainOfExpertise.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertise"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not DomainOfExpertise domainOfExpertise) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a DomainOfExpertise", nameof(thing)); } - var domainOfExpertise = thing as DomainOfExpertise; - if (domainOfExpertise == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a DomainOfExpertise."); + Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertise since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertise.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(domainOfExpertise.Actor.HasValue) + { + writer.WriteStringValue(domainOfExpertise.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertise.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(domainOfExpertise); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs index f2f5fe5de..79cf4552d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ElementDefinition = CDP4Common.DTO.ElementDefinition; /// /// The purpose of the class is to provide a specific serializer @@ -44,89 +50,964 @@ namespace CDP4JsonSerializer public class ElementDefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "containedElement", containedElement => new JArray(containedElement) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "organizationalParticipant", organizationalParticipant => new JArray(organizationalParticipant) }, - { "owner", owner => new JValue(owner) }, - { "parameter", parameter => new JArray(parameter) }, - { "parameterGroup", parameterGroup => new JArray(parameterGroup) }, - { "referencedElement", referencedElement => new JArray(referencedElement) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ElementDefinition elementDefinition) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](elementDefinition.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](elementDefinition.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), elementDefinition.ClassKind))); - jsonObject.Add("containedElement", this.PropertySerializerMap["containedElement"](elementDefinition.ContainedElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](elementDefinition.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](elementDefinition.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](elementDefinition.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](elementDefinition.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](elementDefinition.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](elementDefinition.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](elementDefinition.Name)); - jsonObject.Add("organizationalParticipant", this.PropertySerializerMap["organizationalParticipant"](elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](elementDefinition.Owner)); - jsonObject.Add("parameter", this.PropertySerializerMap["parameter"](elementDefinition.Parameter.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("parameterGroup", this.PropertySerializerMap["parameterGroup"](elementDefinition.ParameterGroup.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("referencedElement", this.PropertySerializerMap["referencedElement"](elementDefinition.ReferencedElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](elementDefinition.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](elementDefinition.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](elementDefinition.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "containedelement": + var allowedVersionsForContainedElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainedElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("containedElement"u8); + + if(value is IEnumerable objectListContainedElement) + { + foreach(var containedElementItem in objectListContainedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "organizationalparticipant": + var allowedVersionsForOrganizationalParticipant = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganizationalParticipant.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("organizationalParticipant"u8); + + if(value is IEnumerable objectListOrganizationalParticipant) + { + foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + } + + writer.WriteEndArray(); + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parameter": + var allowedVersionsForParameter = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameter.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameter"u8); + + if(value is IEnumerable objectListParameter) + { + foreach(var parameterItem in objectListParameter.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } + } + + writer.WriteEndArray(); + break; + case "parametergroup": + var allowedVersionsForParameterGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterGroup"u8); + + if(value is IEnumerable objectListParameterGroup) + { + foreach(var parameterGroupItem in objectListParameterGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } + } + + writer.WriteEndArray(); + break; + case "referencedelement": + var allowedVersionsForReferencedElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("referencedElement"u8); + + if(value is IEnumerable objectListReferencedElement) + { + foreach(var referencedElementItem in objectListReferencedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementDefinition"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ElementDefinition elementDefinition) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ElementDefinition", nameof(thing)); } - var elementDefinition = thing as ElementDefinition; - if (elementDefinition == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ElementDefinition."); + Logger.Log(LogLevel.Info, "Skipping serialization of ElementDefinition since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); + + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); + + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parameterGroup"u8); + + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referencedElement"u8); + + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); + + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); + + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parameterGroup"u8); + + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referencedElement"u8); + + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); + + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WriteStartArray("organizationalParticipant"u8); + + foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); + + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parameterGroup"u8); + + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referencedElement"u8); + + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementDefinition.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(elementDefinition.Actor.HasValue) + { + writer.WriteStringValue(elementDefinition.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); + + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WriteStartArray("organizationalParticipant"u8); + + foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); + + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parameterGroup"u8); + + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referencedElement"u8); + + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementDefinition.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(elementDefinition); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs index 6398d0a3f..1653d0d9a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ElementUsage = CDP4Common.DTO.ElementUsage; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,876 @@ namespace CDP4JsonSerializer public class ElementUsageSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "elementDefinition", elementDefinition => new JValue(elementDefinition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "excludeOption", excludeOption => new JArray(excludeOption) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "interfaceEnd", interfaceEnd => new JValue(interfaceEnd.ToString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterOverride", parameterOverride => new JArray(parameterOverride) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ElementUsage elementUsage) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](elementUsage.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](elementUsage.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), elementUsage.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](elementUsage.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("elementDefinition", this.PropertySerializerMap["elementDefinition"](elementUsage.ElementDefinition)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](elementUsage.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](elementUsage.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludeOption", this.PropertySerializerMap["excludeOption"](elementUsage.ExcludeOption.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](elementUsage.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](elementUsage.Iid)); - jsonObject.Add("interfaceEnd", this.PropertySerializerMap["interfaceEnd"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.InterfaceEndKind), elementUsage.InterfaceEnd))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](elementUsage.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](elementUsage.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](elementUsage.Owner)); - jsonObject.Add("parameterOverride", this.PropertySerializerMap["parameterOverride"](elementUsage.ParameterOverride.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](elementUsage.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](elementUsage.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](elementUsage.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "elementdefinition": + var allowedVersionsForElementDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForElementDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("elementDefinition"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeoption": + var allowedVersionsForExcludeOption = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludeOption.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludeOption"u8); + + if(value is IEnumerable objectListExcludeOption) + { + foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "interfaceend": + var allowedVersionsForInterfaceEnd = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForInterfaceEnd.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("interfaceEnd"u8); + + if(value != null) + { + writer.WriteStringValue(((InterfaceEndKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parameteroverride": + var allowedVersionsForParameterOverride = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterOverride.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterOverride"u8); + + if(value is IEnumerable objectListParameterOverride) + { + foreach(var parameterOverrideItem in objectListParameterOverride.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementUsage"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ElementUsage elementUsage) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ElementUsage", nameof(thing)); } - var elementUsage = thing as ElementUsage; - if (elementUsage == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ElementUsage."); + Logger.Log(LogLevel.Info, "Skipping serialization of ElementUsage since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementUsage.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(elementUsage.Actor.HasValue) + { + writer.WriteStringValue(elementUsage.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); + + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementUsage.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(elementUsage); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs index c1336a7eb..806e68b7f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EmailAddress = CDP4Common.DTO.EmailAddress; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class EmailAddressSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(value) }, - { "vcardType", vcardType => new JValue(vcardType.ToString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EmailAddress emailAddress) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), emailAddress.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](emailAddress.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](emailAddress.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](emailAddress.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](emailAddress.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](emailAddress.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](emailAddress.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](emailAddress.Value)); - jsonObject.Add("vcardType", this.PropertySerializerMap["vcardType"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.VcardEmailAddressKind), emailAddress.VcardType))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("value"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "vcardtype": + var allowedVersionsForVcardType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForVcardType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("vcardType"u8); + + if(value != null) + { + writer.WriteStringValue(((VcardEmailAddressKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EmailAddress"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EmailAddress emailAddress) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a EmailAddress", nameof(thing)); } - var emailAddress = thing as EmailAddress; - if (emailAddress == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of EmailAddress since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a EmailAddress."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(emailAddress.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(emailAddress.Actor.HasValue) + { + writer.WriteStringValue(emailAddress.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(emailAddress.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(emailAddress); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs index 591cacaea..b2c6ba21d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EngineeringModelDataDiscussionItem = CDP4Common.DTO.EngineeringModelDataDiscussionItem; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,528 @@ namespace CDP4JsonSerializer public class EngineeringModelDataDiscussionItemSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "replyTo", replyTo => new JValue(replyTo) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EngineeringModelDataDiscussionItem engineeringModelDataDiscussionItem) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](engineeringModelDataDiscussionItem.Author)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), engineeringModelDataDiscussionItem.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](engineeringModelDataDiscussionItem.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](engineeringModelDataDiscussionItem.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](engineeringModelDataDiscussionItem.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](engineeringModelDataDiscussionItem.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](engineeringModelDataDiscussionItem.ModifiedOn)); - jsonObject.Add("replyTo", this.PropertySerializerMap["replyTo"](engineeringModelDataDiscussionItem.ReplyTo)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](engineeringModelDataDiscussionItem.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](engineeringModelDataDiscussionItem.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "replyto": + var allowedVersionsForReplyTo = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReplyTo.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("replyTo"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModelDataDiscussionItem"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EngineeringModelDataDiscussionItem engineeringModelDataDiscussionItem) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a EngineeringModelDataDiscussionItem", nameof(thing)); } - var engineeringModelDataDiscussionItem = thing as EngineeringModelDataDiscussionItem; - if (engineeringModelDataDiscussionItem == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a EngineeringModelDataDiscussionItem."); + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataDiscussionItem since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModelDataDiscussionItem.Actor.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(engineeringModelDataDiscussionItem); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs index 01ee7fb87..58c900552 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EngineeringModelDataNote = CDP4Common.DTO.EngineeringModelDataNote; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,626 @@ namespace CDP4JsonSerializer public class EngineeringModelDataNoteSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EngineeringModelDataNote engineeringModelDataNote) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](engineeringModelDataNote.Author)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), engineeringModelDataNote.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](engineeringModelDataNote.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](engineeringModelDataNote.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](engineeringModelDataNote.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](engineeringModelDataNote.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](engineeringModelDataNote.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](engineeringModelDataNote.ModifiedOn)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](engineeringModelDataNote.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](engineeringModelDataNote.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](engineeringModelDataNote.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModelDataNote"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EngineeringModelDataNote engineeringModelDataNote) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a EngineeringModelDataNote", nameof(thing)); } - var engineeringModelDataNote = thing as EngineeringModelDataNote; - if (engineeringModelDataNote == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a EngineeringModelDataNote."); + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModelDataNote.Actor.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(engineeringModelDataNote); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs index 00542d683..e1215330c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EngineeringModel = CDP4Common.DTO.EngineeringModel; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,747 @@ namespace CDP4JsonSerializer public class EngineeringModelSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "book", book => new JArray(((IEnumerable)book).Cast().Select(x => x.ToJsonObject())) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "commonFileStore", commonFileStore => new JArray(commonFileStore) }, - { "engineeringModelSetup", engineeringModelSetup => new JValue(engineeringModelSetup) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "genericNote", genericNote => new JArray(genericNote) }, - { "iid", iid => new JValue(iid) }, - { "iteration", iteration => new JArray(iteration) }, - { "lastModifiedOn", lastModifiedOn => new JValue(((DateTime)lastModifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "logEntry", logEntry => new JArray(logEntry) }, - { "modellingAnnotation", modellingAnnotation => new JArray(modellingAnnotation) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EngineeringModel engineeringModel) - { - var jsonObject = new JObject(); - jsonObject.Add("book", this.PropertySerializerMap["book"](engineeringModel.Book.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), engineeringModel.ClassKind))); - jsonObject.Add("commonFileStore", this.PropertySerializerMap["commonFileStore"](engineeringModel.CommonFileStore)); - jsonObject.Add("engineeringModelSetup", this.PropertySerializerMap["engineeringModelSetup"](engineeringModel.EngineeringModelSetup)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](engineeringModel.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](engineeringModel.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("genericNote", this.PropertySerializerMap["genericNote"](engineeringModel.GenericNote.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](engineeringModel.Iid)); - jsonObject.Add("iteration", this.PropertySerializerMap["iteration"](engineeringModel.Iteration.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("lastModifiedOn", this.PropertySerializerMap["lastModifiedOn"](engineeringModel.LastModifiedOn)); - jsonObject.Add("logEntry", this.PropertySerializerMap["logEntry"](engineeringModel.LogEntry.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("modellingAnnotation", this.PropertySerializerMap["modellingAnnotation"](engineeringModel.ModellingAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](engineeringModel.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](engineeringModel.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](engineeringModel.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "book": + var allowedVersionsForBook = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBook.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("book"u8); + + if(value is IEnumerable objectListBook) + { + foreach(var bookItem in objectListBook.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(bookItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "commonfilestore": + var allowedVersionsForCommonFileStore = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCommonFileStore.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("commonFileStore"u8); + + if(value is IEnumerable objectListCommonFileStore) + { + foreach(var commonFileStoreItem in objectListCommonFileStore.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + } + + writer.WriteEndArray(); + break; + case "engineeringmodelsetup": + var allowedVersionsForEngineeringModelSetup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForEngineeringModelSetup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("engineeringModelSetup"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "genericnote": + var allowedVersionsForGenericNote = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGenericNote.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("genericNote"u8); + + if(value is IEnumerable objectListGenericNote) + { + foreach(var genericNoteItem in objectListGenericNote.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(genericNoteItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iteration": + var allowedVersionsForIteration = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIteration.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("iteration"u8); + + if(value is IEnumerable objectListIteration) + { + foreach(var iterationItem in objectListIteration.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } + } + + writer.WriteEndArray(); + break; + case "lastmodifiedon": + var allowedVersionsForLastModifiedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLastModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("lastModifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logentry": + var allowedVersionsForLogEntry = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLogEntry.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("logEntry"u8); + + if(value is IEnumerable objectListLogEntry) + { + foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + } + + writer.WriteEndArray(); + break; + case "modellingannotation": + var allowedVersionsForModellingAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModellingAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("modellingAnnotation"u8); + + if(value is IEnumerable objectListModellingAnnotation) + { + foreach(var modellingAnnotationItem in objectListModellingAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modellingAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModel"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EngineeringModel engineeringModel) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a EngineeringModel", nameof(thing)); } - var engineeringModel = thing as EngineeringModel; - if (engineeringModel == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a EngineeringModel."); + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModel since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); + + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); + + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.1.0"); + writer.WriteStartArray("book"u8); + + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(bookItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); + + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("genericNote"u8); + + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(genericNoteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); + + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("modellingAnnotation"u8); + + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modellingAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.2.0"); + writer.WriteStartArray("book"u8); + + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(bookItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); + + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("genericNote"u8); + + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(genericNoteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); + + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("modellingAnnotation"u8); + + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modellingAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModel.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModel.Actor.HasValue) + { + writer.WriteStringValue(engineeringModel.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("book"u8); + + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(bookItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); + + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("genericNote"u8); + + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(genericNoteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); + + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("modellingAnnotation"u8); + + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modellingAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModel.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(engineeringModel); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs index de8252109..a26486065 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EngineeringModelSetup = CDP4Common.DTO.EngineeringModelSetup; /// /// The purpose of the class is to provide a specific serializer @@ -44,95 +50,1090 @@ namespace CDP4JsonSerializer public class EngineeringModelSetupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "activeDomain", activeDomain => new JArray(activeDomain) }, - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultOrganizationalParticipant", defaultOrganizationalParticipant => new JValue(defaultOrganizationalParticipant) }, - { "definition", definition => new JArray(definition) }, - { "engineeringModelIid", engineeringModelIid => new JValue(engineeringModelIid) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "iterationSetup", iterationSetup => new JArray(iterationSetup) }, - { "kind", kind => new JValue(kind.ToString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "organizationalParticipant", organizationalParticipant => new JArray(organizationalParticipant) }, - { "participant", participant => new JArray(participant) }, - { "requiredRdl", requiredRdl => new JArray(requiredRdl) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceEngineeringModelSetupIid", sourceEngineeringModelSetupIid => new JValue(sourceEngineeringModelSetupIid) }, - { "studyPhase", studyPhase => new JValue(studyPhase.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EngineeringModelSetup engineeringModelSetup) - { - var jsonObject = new JObject(); - jsonObject.Add("activeDomain", this.PropertySerializerMap["activeDomain"](engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](engineeringModelSetup.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), engineeringModelSetup.ClassKind))); - jsonObject.Add("defaultOrganizationalParticipant", this.PropertySerializerMap["defaultOrganizationalParticipant"](engineeringModelSetup.DefaultOrganizationalParticipant)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](engineeringModelSetup.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("engineeringModelIid", this.PropertySerializerMap["engineeringModelIid"](engineeringModelSetup.EngineeringModelIid)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](engineeringModelSetup.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](engineeringModelSetup.Iid)); - jsonObject.Add("iterationSetup", this.PropertySerializerMap["iterationSetup"](engineeringModelSetup.IterationSetup.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("kind", this.PropertySerializerMap["kind"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.EngineeringModelKind), engineeringModelSetup.Kind))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](engineeringModelSetup.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](engineeringModelSetup.Name)); - jsonObject.Add("organizationalParticipant", this.PropertySerializerMap["organizationalParticipant"](engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("participant", this.PropertySerializerMap["participant"](engineeringModelSetup.Participant.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("requiredRdl", this.PropertySerializerMap["requiredRdl"](engineeringModelSetup.RequiredRdl)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](engineeringModelSetup.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](engineeringModelSetup.ShortName)); - jsonObject.Add("sourceEngineeringModelSetupIid", this.PropertySerializerMap["sourceEngineeringModelSetupIid"](engineeringModelSetup.SourceEngineeringModelSetupIid)); - jsonObject.Add("studyPhase", this.PropertySerializerMap["studyPhase"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.StudyPhaseKind), engineeringModelSetup.StudyPhase))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](engineeringModelSetup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "activedomain": + var allowedVersionsForActiveDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActiveDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("activeDomain"u8); + + if(value is IEnumerable objectListActiveDomain) + { + foreach(var activeDomainItem in objectListActiveDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; + + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultorganizationalparticipant": + var allowedVersionsForDefaultOrganizationalParticipant = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultOrganizationalParticipant.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultOrganizationalParticipant"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "engineeringmodeliid": + var allowedVersionsForEngineeringModelIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForEngineeringModelIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("engineeringModelIid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iterationsetup": + var allowedVersionsForIterationSetup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIterationSetup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("iterationSetup"u8); + + if(value is IEnumerable objectListIterationSetup) + { + foreach(var iterationSetupItem in objectListIterationSetup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + } + + writer.WriteEndArray(); + break; + case "kind": + var allowedVersionsForKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("kind"u8); + + if(value != null) + { + writer.WriteStringValue(((EngineeringModelKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "organizationalparticipant": + var allowedVersionsForOrganizationalParticipant = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganizationalParticipant.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("organizationalParticipant"u8); + + if(value is IEnumerable objectListOrganizationalParticipant) + { + foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + } + + writer.WriteEndArray(); + break; + case "participant": + var allowedVersionsForParticipant = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParticipant.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("participant"u8); + + if(value is IEnumerable objectListParticipant) + { + foreach(var participantItem in objectListParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } + } + + writer.WriteEndArray(); + break; + case "requiredrdl": + var allowedVersionsForRequiredRdl = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("requiredRdl"u8); + + if(value is IEnumerable objectListRequiredRdl) + { + foreach(var requiredRdlItem in objectListRequiredRdl.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceengineeringmodelsetupiid": + var allowedVersionsForSourceEngineeringModelSetupIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceEngineeringModelSetupIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "studyphase": + var allowedVersionsForStudyPhase = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStudyPhase.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("studyPhase"u8); + + if(value != null) + { + writer.WriteStringValue(((StudyPhaseKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModelSetup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EngineeringModelSetup engineeringModelSetup) + { + throw new ArgumentException("The thing shall be a EngineeringModelSetup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelSetup since Version is below 1.0.0"); + return; } - var engineeringModelSetup = thing as EngineeringModelSetup; - if (engineeringModelSetup == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a EngineeringModelSetup."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.0.0"); + writer.WriteStartArray("activeDomain"u8); + + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requiredRdl"u8); + + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.1.0"); + writer.WriteStartArray("activeDomain"u8); + + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requiredRdl"u8); + + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.2.0"); + writer.WriteStartArray("activeDomain"u8); + + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WritePropertyName("defaultOrganizationalParticipant"u8); + + if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("organizationalParticipant"u8); + + foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requiredRdl"u8); + + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelSetup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.3.0"); + writer.WriteStartArray("activeDomain"u8); + + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("actor"u8); + + if(engineeringModelSetup.Actor.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WritePropertyName("defaultOrganizationalParticipant"u8); + + if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("organizationalParticipant"u8); + + foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requiredRdl"u8); + + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + { + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelSetup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(engineeringModelSetup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs index 5a28df53c..17bfcb6e1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EnumerationParameterType = CDP4Common.DTO.EnumerationParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,818 @@ namespace CDP4JsonSerializer public class EnumerationParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "allowMultiSelect", allowMultiSelect => new JValue(allowMultiSelect) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueDefinition", valueDefinition => new JArray(((IEnumerable)valueDefinition).Cast().Select(x => x.ToJsonObject())) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EnumerationParameterType enumerationParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](enumerationParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("allowMultiSelect", this.PropertySerializerMap["allowMultiSelect"](enumerationParameterType.AllowMultiSelect)); - jsonObject.Add("category", this.PropertySerializerMap["category"](enumerationParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), enumerationParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](enumerationParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](enumerationParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](enumerationParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](enumerationParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](enumerationParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](enumerationParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](enumerationParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](enumerationParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](enumerationParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](enumerationParameterType.ThingPreference)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](enumerationParameterType.ValueDefinition.OrderBy(x => x, this.orderedItemComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "allowmultiselect": + var allowedVersionsForAllowMultiSelect = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAllowMultiSelect.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("allowMultiSelect"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EnumerationParameterType enumerationParameterType) + { + throw new ArgumentException("The thing shall be a EnumerationParameterType", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of EnumerationParameterType since Version is below 1.0.0"); + return; } - var enumerationParameterType = thing as EnumerationParameterType; - if (enumerationParameterType == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a EnumerationParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationParameterType.ThingPreference); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(enumerationParameterType.Actor.HasValue) + { + writer.WriteStringValue(enumerationParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationParameterType.ThingPreference); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(enumerationParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs index 6db280244..03c22ebbd 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using EnumerationValueDefinition = CDP4Common.DTO.EnumerationValueDefinition; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,600 @@ namespace CDP4JsonSerializer public class EnumerationValueDefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(EnumerationValueDefinition enumerationValueDefinition) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](enumerationValueDefinition.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), enumerationValueDefinition.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](enumerationValueDefinition.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](enumerationValueDefinition.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](enumerationValueDefinition.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](enumerationValueDefinition.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](enumerationValueDefinition.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](enumerationValueDefinition.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](enumerationValueDefinition.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](enumerationValueDefinition.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationValueDefinition"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not EnumerationValueDefinition enumerationValueDefinition) + { + throw new ArgumentException("The thing shall be a EnumerationValueDefinition", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of EnumerationValueDefinition since Version is below 1.0.0"); + return; } - var enumerationValueDefinition = thing as EnumerationValueDefinition; - if (enumerationValueDefinition == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a EnumerationValueDefinition."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationValueDefinition.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationValueDefinition.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationValueDefinition.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationValueDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationValueDefinition.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(enumerationValueDefinition.Actor.HasValue) + { + writer.WriteStringValue(enumerationValueDefinition.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationValueDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationValueDefinition.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(enumerationValueDefinition); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs index f862c9c34..53ec45716 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ExclusiveOrExpression = CDP4Common.DTO.ExclusiveOrExpression; /// /// The purpose of the class is to provide a specific serializer @@ -44,67 +50,416 @@ namespace CDP4JsonSerializer public class ExclusiveOrExpressionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "term", term => new JArray(term) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ExclusiveOrExpression exclusiveOrExpression) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), exclusiveOrExpression.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](exclusiveOrExpression.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](exclusiveOrExpression.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](exclusiveOrExpression.RevisionNumber)); - jsonObject.Add("term", this.PropertySerializerMap["term"](exclusiveOrExpression.Term.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](exclusiveOrExpression.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "term": + var allowedVersionsForTerm = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTerm.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("term"u8); + + if(value is IEnumerable objectListTerm) + { + foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ExclusiveOrExpression"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ExclusiveOrExpression exclusiveOrExpression) + { + throw new ArgumentException("The thing shall be a ExclusiveOrExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ExclusiveOrExpression since Version is below 1.0.0"); + return; } - var exclusiveOrExpression = thing as ExclusiveOrExpression; - if (exclusiveOrExpression == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ExclusiveOrExpression."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(exclusiveOrExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(exclusiveOrExpression.Actor.HasValue) + { + writer.WriteStringValue(exclusiveOrExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(exclusiveOrExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(exclusiveOrExpression); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs index a69eed343..90f4cc197 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ExternalIdentifierMap = CDP4Common.DTO.ExternalIdentifierMap; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,656 @@ namespace CDP4JsonSerializer public class ExternalIdentifierMapSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "correspondence", correspondence => new JArray(correspondence) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "externalFormat", externalFormat => new JValue(externalFormat) }, - { "externalModelName", externalModelName => new JValue(externalModelName) }, - { "externalToolName", externalToolName => new JValue(externalToolName) }, - { "externalToolVersion", externalToolVersion => new JValue(externalToolVersion) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ExternalIdentifierMap externalIdentifierMap) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), externalIdentifierMap.ClassKind))); - jsonObject.Add("correspondence", this.PropertySerializerMap["correspondence"](externalIdentifierMap.Correspondence.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("externalFormat", this.PropertySerializerMap["externalFormat"](externalIdentifierMap.ExternalFormat)); - jsonObject.Add("externalModelName", this.PropertySerializerMap["externalModelName"](externalIdentifierMap.ExternalModelName)); - jsonObject.Add("externalToolName", this.PropertySerializerMap["externalToolName"](externalIdentifierMap.ExternalToolName)); - jsonObject.Add("externalToolVersion", this.PropertySerializerMap["externalToolVersion"](externalIdentifierMap.ExternalToolVersion)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](externalIdentifierMap.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](externalIdentifierMap.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](externalIdentifierMap.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](externalIdentifierMap.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](externalIdentifierMap.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](externalIdentifierMap.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "correspondence": + var allowedVersionsForCorrespondence = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCorrespondence.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("correspondence"u8); + + if(value is IEnumerable objectListCorrespondence) + { + foreach(var correspondenceItem in objectListCorrespondence.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "externalformat": + var allowedVersionsForExternalFormat = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalFormat.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("externalFormat"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "externalmodelname": + var allowedVersionsForExternalModelName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalModelName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("externalModelName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "externaltoolname": + var allowedVersionsForExternalToolName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalToolName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("externalToolName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "externaltoolversion": + var allowedVersionsForExternalToolVersion = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalToolVersion.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("externalToolVersion"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ExternalIdentifierMap"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ExternalIdentifierMap externalIdentifierMap) + { + throw new ArgumentException("The thing shall be a ExternalIdentifierMap", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ExternalIdentifierMap since Version is below 1.0.0"); + return; } - var externalIdentifierMap = thing as ExternalIdentifierMap; - if (externalIdentifierMap == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ExternalIdentifierMap."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(externalIdentifierMap.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(externalIdentifierMap.Actor.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(externalIdentifierMap.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(externalIdentifierMap); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs index 088c56547..3fe0cb979 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using FileRevision = CDP4Common.DTO.FileRevision; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,622 @@ namespace CDP4JsonSerializer public class FileRevisionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "containingFolder", containingFolder => new JValue(containingFolder) }, - { "contentHash", contentHash => new JValue(contentHash) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "creator", creator => new JValue(creator) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fileType", fileType => new JArray(((IEnumerable)fileType).Cast().Select(x => x.ToJsonObject())) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(FileRevision fileRevision) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), fileRevision.ClassKind))); - jsonObject.Add("containingFolder", this.PropertySerializerMap["containingFolder"](fileRevision.ContainingFolder)); - jsonObject.Add("contentHash", this.PropertySerializerMap["contentHash"](fileRevision.ContentHash)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](fileRevision.CreatedOn)); - jsonObject.Add("creator", this.PropertySerializerMap["creator"](fileRevision.Creator)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](fileRevision.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](fileRevision.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fileType", this.PropertySerializerMap["fileType"](fileRevision.FileType.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](fileRevision.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](fileRevision.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](fileRevision.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](fileRevision.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](fileRevision.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "containingfolder": + var allowedVersionsForContainingFolder = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainingFolder.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("containingFolder"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "contenthash": + var allowedVersionsForContentHash = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContentHash.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("contentHash"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "creator": + var allowedVersionsForCreator = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreator.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("creator"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filetype": + var allowedVersionsForFileType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFileType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("fileType"u8); + + if(value is IEnumerable objectListFileType) + { + foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the FileRevision"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not FileRevision fileRevision) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a FileRevision", nameof(thing)); } - var fileRevision = thing as FileRevision; - if (fileRevision == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a FileRevision."); + Logger.Log(LogLevel.Info, "Skipping serialization of FileRevision since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileRevision.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(fileRevision.Actor.HasValue) + { + writer.WriteStringValue(fileRevision.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileRevision.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(fileRevision); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs index 77d02b75e..402554d07 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using File = CDP4Common.DTO.File; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,578 @@ namespace CDP4JsonSerializer public class FileSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fileRevision", fileRevision => new JArray(fileRevision) }, - { "iid", iid => new JValue(iid) }, - { "lockedBy", lockedBy => new JValue(lockedBy) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(File file) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](file.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), file.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](file.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](file.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fileRevision", this.PropertySerializerMap["fileRevision"](file.FileRevision.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](file.Iid)); - jsonObject.Add("lockedBy", this.PropertySerializerMap["lockedBy"](file.LockedBy)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](file.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](file.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](file.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](file.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filerevision": + var allowedVersionsForFileRevision = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFileRevision.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("fileRevision"u8); + + if(value is IEnumerable objectListFileRevision) + { + foreach(var fileRevisionItem in objectListFileRevision.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "lockedby": + var allowedVersionsForLockedBy = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLockedBy.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("lockedBy"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the File"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not File file) + { + throw new ArgumentException("The thing shall be a File", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of File since Version is below 1.0.0"); + return; } - var file = thing as File; - if (file == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a File."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing File for Version 1.0.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(file.ClassKind.ToString()); + writer.WriteStartArray("fileRevision"u8); + + foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(file.Iid); + writer.WritePropertyName("lockedBy"u8); + + if(file.LockedBy.HasValue) + { + writer.WriteStringValue(file.LockedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(file.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(file.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing File for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(file.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in file.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); + + foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(file.Iid); + writer.WritePropertyName("lockedBy"u8); + + if(file.LockedBy.HasValue) + { + writer.WriteStringValue(file.LockedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(file.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(file.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(file.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing File for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(file.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in file.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); + + foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(file.Iid); + writer.WritePropertyName("lockedBy"u8); + + if(file.LockedBy.HasValue) + { + writer.WriteStringValue(file.LockedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(file.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(file.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(file.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(file.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing File for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(file.Actor.HasValue) + { + writer.WriteStringValue(file.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(file.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in file.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); + + foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(file.Iid); + writer.WritePropertyName("lockedBy"u8); + + if(file.LockedBy.HasValue) + { + writer.WriteStringValue(file.LockedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(file.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(file.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(file.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(file.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(file); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs index 70b0d6254..71b13359f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using FileType = CDP4Common.DTO.FileType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class FileTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "extension", extension => new JValue(extension) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(FileType fileType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](fileType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](fileType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), fileType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](fileType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](fileType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](fileType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("extension", this.PropertySerializerMap["extension"](fileType.Extension)); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](fileType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](fileType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](fileType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](fileType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](fileType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](fileType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](fileType.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](fileType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "extension": + var allowedVersionsForExtension = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExtension.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("extension"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the FileType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not FileType fileType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a FileType", nameof(thing)); } - var fileType = thing as FileType; - if (fileType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of FileType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a FileType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(fileType.Actor.HasValue) + { + writer.WriteStringValue(fileType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(fileType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs index 7498f4963..fa69502d8 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Folder = CDP4Common.DTO.Folder; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,564 @@ namespace CDP4JsonSerializer public class FolderSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "containingFolder", containingFolder => new JValue(containingFolder) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "creator", creator => new JValue(creator) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Folder folder) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), folder.ClassKind))); - jsonObject.Add("containingFolder", this.PropertySerializerMap["containingFolder"](folder.ContainingFolder)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](folder.CreatedOn)); - jsonObject.Add("creator", this.PropertySerializerMap["creator"](folder.Creator)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](folder.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](folder.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](folder.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](folder.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](folder.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](folder.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](folder.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](folder.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "containingfolder": + var allowedVersionsForContainingFolder = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainingFolder.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("containingFolder"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "creator": + var allowedVersionsForCreator = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreator.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("creator"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Folder"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Folder folder) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Folder", nameof(thing)); } - var folder = thing as Folder; - if (folder == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Folder since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Folder."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(folder.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(folder.Actor.HasValue) + { + writer.WriteStringValue(folder.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(folder.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(folder); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs index c3bd06769..b6bdf9a64 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Glossary = CDP4Common.DTO.Glossary; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,750 @@ namespace CDP4JsonSerializer public class GlossarySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "term", term => new JArray(term) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Glossary glossary) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](glossary.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](glossary.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), glossary.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](glossary.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](glossary.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](glossary.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](glossary.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](glossary.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](glossary.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](glossary.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](glossary.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](glossary.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](glossary.ShortName)); - jsonObject.Add("term", this.PropertySerializerMap["term"](glossary.Term.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](glossary.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "term": + var allowedVersionsForTerm = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTerm.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("term"u8); + + if(value is IEnumerable objectListTerm) + { + foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Glossary"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Glossary glossary) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Glossary", nameof(thing)); } - var glossary = thing as Glossary; - if (glossary == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a Glossary."); + Logger.Log(LogLevel.Info, "Skipping serialization of Glossary since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); + + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); + + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); + + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(glossary.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(glossary.Actor.HasValue) + { + writer.WriteStringValue(glossary.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); + + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(glossary.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(glossary); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs index bf95adc37..6d418939f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Goal = CDP4Common.DTO.Goal; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,604 @@ namespace CDP4JsonSerializer public class GoalSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Goal goal) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](goal.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](goal.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), goal.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](goal.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](goal.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](goal.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](goal.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](goal.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](goal.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](goal.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](goal.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](goal.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](goal.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Goal"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Goal goal) + { + throw new ArgumentException("The thing shall be a Goal", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Goal since Version is below 1.1.0"); + return; } - var goal = thing as Goal; - if (goal == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Goal."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(goal.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(goal.Actor.HasValue) + { + writer.WriteStringValue(goal.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(goal.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(goal); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs index 8d65c3abc..13174fe29 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using HyperLink = CDP4Common.DTO.HyperLink; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class HyperLinkSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "uri", uri => new JValue(uri) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(HyperLink hyperLink) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), hyperLink.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](hyperLink.Content)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](hyperLink.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](hyperLink.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](hyperLink.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](hyperLink.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](hyperLink.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](hyperLink.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](hyperLink.ThingPreference)); - jsonObject.Add("uri", this.PropertySerializerMap["uri"](hyperLink.Uri)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "uri": + var allowedVersionsForUri = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUri.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("uri"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the HyperLink"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not HyperLink hyperLink) + { + throw new ArgumentException("The thing shall be a HyperLink", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of HyperLink since Version is below 1.0.0"); + return; } - var hyperLink = thing as HyperLink; - if (hyperLink == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a HyperLink."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(hyperLink.ThingPreference); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(hyperLink.Actor.HasValue) + { + writer.WriteStringValue(hyperLink.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(hyperLink.ThingPreference); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(hyperLink); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs index 5eee3c5bf..e5921d733 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using IdCorrespondence = CDP4Common.DTO.IdCorrespondence; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class IdCorrespondenceSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "externalId", externalId => new JValue(externalId) }, - { "iid", iid => new JValue(iid) }, - { "internalThing", internalThing => new JValue(internalThing) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(IdCorrespondence idCorrespondence) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), idCorrespondence.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](idCorrespondence.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](idCorrespondence.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("externalId", this.PropertySerializerMap["externalId"](idCorrespondence.ExternalId)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](idCorrespondence.Iid)); - jsonObject.Add("internalThing", this.PropertySerializerMap["internalThing"](idCorrespondence.InternalThing)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](idCorrespondence.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](idCorrespondence.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](idCorrespondence.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "externalid": + var allowedVersionsForExternalId = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalId.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("externalId"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "internalthing": + var allowedVersionsForInternalThing = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForInternalThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("internalThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the IdCorrespondence"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not IdCorrespondence idCorrespondence) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a IdCorrespondence", nameof(thing)); } - var idCorrespondence = thing as IdCorrespondence; - if (idCorrespondence == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of IdCorrespondence since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a IdCorrespondence."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(idCorrespondence.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(idCorrespondence.Actor.HasValue) + { + writer.WriteStringValue(idCorrespondence.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(idCorrespondence.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(idCorrespondence); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs index 092289767..ef20fd8f1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using IndependentParameterTypeAssignment = CDP4Common.DTO.IndependentParameterTypeAssignment; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,390 @@ namespace CDP4JsonSerializer public class IndependentParameterTypeAssignmentSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "measurementScale", measurementScale => new JValue(measurementScale) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(IndependentParameterTypeAssignment independentParameterTypeAssignment) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), independentParameterTypeAssignment.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](independentParameterTypeAssignment.Iid)); - jsonObject.Add("measurementScale", this.PropertySerializerMap["measurementScale"](independentParameterTypeAssignment.MeasurementScale)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](independentParameterTypeAssignment.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](independentParameterTypeAssignment.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](independentParameterTypeAssignment.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](independentParameterTypeAssignment.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "measurementscale": + var allowedVersionsForMeasurementScale = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMeasurementScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("measurementScale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the IndependentParameterTypeAssignment"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not IndependentParameterTypeAssignment independentParameterTypeAssignment) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a IndependentParameterTypeAssignment", nameof(thing)); } - var independentParameterTypeAssignment = thing as IndependentParameterTypeAssignment; - if (independentParameterTypeAssignment == null) + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of IndependentParameterTypeAssignment since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a IndependentParameterTypeAssignment."); + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing IndependentParameterTypeAssignment for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(independentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(independentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing IndependentParameterTypeAssignment for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(independentParameterTypeAssignment.Actor.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(independentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(independentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(independentParameterTypeAssignment); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs index 1d4cd1f28..3dfd5bc22 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using IntervalScale = CDP4Common.DTO.IntervalScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,97 +50,1022 @@ namespace CDP4JsonSerializer public class IntervalScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isMaximumInclusive", isMaximumInclusive => new JValue(isMaximumInclusive) }, - { "isMinimumInclusive", isMinimumInclusive => new JValue(isMinimumInclusive) }, - { "mappingToReferenceScale", mappingToReferenceScale => new JArray(mappingToReferenceScale) }, - { "maximumPermissibleValue", maximumPermissibleValue => new JValue(maximumPermissibleValue) }, - { "minimumPermissibleValue", minimumPermissibleValue => new JValue(minimumPermissibleValue) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "negativeValueConnotation", negativeValueConnotation => new JValue(negativeValueConnotation) }, - { "numberSet", numberSet => new JValue(numberSet.ToString()) }, - { "positiveValueConnotation", positiveValueConnotation => new JValue(positiveValueConnotation) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - { "valueDefinition", valueDefinition => new JArray(valueDefinition) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(IntervalScale intervalScale) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](intervalScale.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), intervalScale.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](intervalScale.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](intervalScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](intervalScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](intervalScale.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](intervalScale.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](intervalScale.IsDeprecated)); - jsonObject.Add("isMaximumInclusive", this.PropertySerializerMap["isMaximumInclusive"](intervalScale.IsMaximumInclusive)); - jsonObject.Add("isMinimumInclusive", this.PropertySerializerMap["isMinimumInclusive"](intervalScale.IsMinimumInclusive)); - jsonObject.Add("mappingToReferenceScale", this.PropertySerializerMap["mappingToReferenceScale"](intervalScale.MappingToReferenceScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("maximumPermissibleValue", this.PropertySerializerMap["maximumPermissibleValue"](intervalScale.MaximumPermissibleValue)); - jsonObject.Add("minimumPermissibleValue", this.PropertySerializerMap["minimumPermissibleValue"](intervalScale.MinimumPermissibleValue)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](intervalScale.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](intervalScale.Name)); - jsonObject.Add("negativeValueConnotation", this.PropertySerializerMap["negativeValueConnotation"](intervalScale.NegativeValueConnotation)); - jsonObject.Add("numberSet", this.PropertySerializerMap["numberSet"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.NumberSetKind), intervalScale.NumberSet))); - jsonObject.Add("positiveValueConnotation", this.PropertySerializerMap["positiveValueConnotation"](intervalScale.PositiveValueConnotation)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](intervalScale.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](intervalScale.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](intervalScale.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](intervalScale.Unit)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](intervalScale.ValueDefinition.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + var allowedVersionsForIsMaximumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + var allowedVersionsForIsMinimumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + var allowedVersionsForMappingToReferenceScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + var allowedVersionsForMaximumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minimumpermissiblevalue": + var allowedVersionsForMinimumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + var allowedVersionsForNegativeValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + var allowedVersionsForNumberSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + var allowedVersionsForPositiveValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the IntervalScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not IntervalScale intervalScale) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a IntervalScale", nameof(thing)); } - var intervalScale = thing as IntervalScale; - if (intervalScale == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a IntervalScale."); + Logger.Log(LogLevel.Info, "Skipping serialization of IntervalScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(intervalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(intervalScale.Actor.HasValue) + { + writer.WriteStringValue(intervalScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(intervalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(intervalScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs index 95bf1f9e6..618c3355b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Iteration = CDP4Common.DTO.Iteration; /// /// The purpose of the class is to provide a specific serializer @@ -44,107 +50,1525 @@ namespace CDP4JsonSerializer public class IterationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "actualFiniteStateList", actualFiniteStateList => new JArray(actualFiniteStateList) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultOption", defaultOption => new JValue(defaultOption) }, - { "diagramCanvas", diagramCanvas => new JArray(diagramCanvas) }, - { "domainFileStore", domainFileStore => new JArray(domainFileStore) }, - { "element", element => new JArray(element) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "externalIdentifierMap", externalIdentifierMap => new JArray(externalIdentifierMap) }, - { "goal", goal => new JArray(goal) }, - { "iid", iid => new JValue(iid) }, - { "iterationSetup", iterationSetup => new JValue(iterationSetup) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "option", option => new JArray(((IEnumerable)option).Cast().Select(x => x.ToJsonObject())) }, - { "possibleFiniteStateList", possibleFiniteStateList => new JArray(possibleFiniteStateList) }, - { "publication", publication => new JArray(publication) }, - { "relationship", relationship => new JArray(relationship) }, - { "requirementsSpecification", requirementsSpecification => new JArray(requirementsSpecification) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "ruleVerificationList", ruleVerificationList => new JArray(ruleVerificationList) }, - { "sharedDiagramStyle", sharedDiagramStyle => new JArray(sharedDiagramStyle) }, - { "sourceIterationIid", sourceIterationIid => new JValue(sourceIterationIid) }, - { "stakeholder", stakeholder => new JArray(stakeholder) }, - { "stakeholderValue", stakeholderValue => new JArray(stakeholderValue) }, - { "stakeholderValueMap", stakeholderValueMap => new JArray(stakeholderValueMap) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "topElement", topElement => new JValue(topElement) }, - { "valueGroup", valueGroup => new JArray(valueGroup) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Iteration iteration) - { - var jsonObject = new JObject(); - jsonObject.Add("actualFiniteStateList", this.PropertySerializerMap["actualFiniteStateList"](iteration.ActualFiniteStateList.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), iteration.ClassKind))); - jsonObject.Add("defaultOption", this.PropertySerializerMap["defaultOption"](iteration.DefaultOption)); - jsonObject.Add("diagramCanvas", this.PropertySerializerMap["diagramCanvas"](iteration.DiagramCanvas.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("domainFileStore", this.PropertySerializerMap["domainFileStore"](iteration.DomainFileStore.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("element", this.PropertySerializerMap["element"](iteration.Element.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](iteration.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](iteration.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("externalIdentifierMap", this.PropertySerializerMap["externalIdentifierMap"](iteration.ExternalIdentifierMap.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("goal", this.PropertySerializerMap["goal"](iteration.Goal.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](iteration.Iid)); - jsonObject.Add("iterationSetup", this.PropertySerializerMap["iterationSetup"](iteration.IterationSetup)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](iteration.ModifiedOn)); - jsonObject.Add("option", this.PropertySerializerMap["option"](iteration.Option.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("possibleFiniteStateList", this.PropertySerializerMap["possibleFiniteStateList"](iteration.PossibleFiniteStateList.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("publication", this.PropertySerializerMap["publication"](iteration.Publication.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("relationship", this.PropertySerializerMap["relationship"](iteration.Relationship.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("requirementsSpecification", this.PropertySerializerMap["requirementsSpecification"](iteration.RequirementsSpecification.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](iteration.RevisionNumber)); - jsonObject.Add("ruleVerificationList", this.PropertySerializerMap["ruleVerificationList"](iteration.RuleVerificationList.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("sharedDiagramStyle", this.PropertySerializerMap["sharedDiagramStyle"](iteration.SharedDiagramStyle.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("sourceIterationIid", this.PropertySerializerMap["sourceIterationIid"](iteration.SourceIterationIid)); - jsonObject.Add("stakeholder", this.PropertySerializerMap["stakeholder"](iteration.Stakeholder.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("stakeholderValue", this.PropertySerializerMap["stakeholderValue"](iteration.StakeholderValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("stakeholderValueMap", this.PropertySerializerMap["stakeholderValueMap"](iteration.StakeholderValueMap.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](iteration.ThingPreference)); - jsonObject.Add("topElement", this.PropertySerializerMap["topElement"](iteration.TopElement)); - jsonObject.Add("valueGroup", this.PropertySerializerMap["valueGroup"](iteration.ValueGroup.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualfinitestatelist": + var allowedVersionsForActualFiniteStateList = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualFiniteStateList.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("actualFiniteStateList"u8); + + if(value is IEnumerable objectListActualFiniteStateList) + { + foreach(var actualFiniteStateListItem in objectListActualFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultoption": + var allowedVersionsForDefaultOption = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultOption.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultOption"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "diagramcanvas": + var allowedVersionsForDiagramCanvas = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiagramCanvas.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("diagramCanvas"u8); + + if(value is IEnumerable objectListDiagramCanvas) + { + foreach(var diagramCanvasItem in objectListDiagramCanvas.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } + } + + writer.WriteEndArray(); + break; + case "domainfilestore": + var allowedVersionsForDomainFileStore = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomainFileStore.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domainFileStore"u8); + + if(value is IEnumerable objectListDomainFileStore) + { + foreach(var domainFileStoreItem in objectListDomainFileStore.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } + } + + writer.WriteEndArray(); + break; + case "element": + var allowedVersionsForElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("element"u8); + + if(value is IEnumerable objectListElement) + { + foreach(var elementItem in objectListElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "externalidentifiermap": + var allowedVersionsForExternalIdentifierMap = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExternalIdentifierMap.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("externalIdentifierMap"u8); + + if(value is IEnumerable objectListExternalIdentifierMap) + { + foreach(var externalIdentifierMapItem in objectListExternalIdentifierMap.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } + } + + writer.WriteEndArray(); + break; + case "goal": + var allowedVersionsForGoal = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGoal.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("goal"u8); + + if(value is IEnumerable objectListGoal) + { + foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iterationsetup": + var allowedVersionsForIterationSetup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIterationSetup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iterationSetup"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "option": + var allowedVersionsForOption = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOption.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("option"u8); + + if(value is IEnumerable objectListOption) + { + foreach(var optionItem in objectListOption.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } + } + + writer.WriteEndArray(); + break; + case "possiblefinitestatelist": + var allowedVersionsForPossibleFiniteStateList = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleFiniteStateList.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleFiniteStateList"u8); + + if(value is IEnumerable objectListPossibleFiniteStateList) + { + foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + } + + writer.WriteEndArray(); + break; + case "publication": + var allowedVersionsForPublication = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublication.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("publication"u8); + + if(value is IEnumerable objectListPublication) + { + foreach(var publicationItem in objectListPublication.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } + } + + writer.WriteEndArray(); + break; + case "relationship": + var allowedVersionsForRelationship = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelationship.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relationship"u8); + + if(value is IEnumerable objectListRelationship) + { + foreach(var relationshipItem in objectListRelationship.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } + } + + writer.WriteEndArray(); + break; + case "requirementsspecification": + var allowedVersionsForRequirementsSpecification = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequirementsSpecification.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("requirementsSpecification"u8); + + if(value is IEnumerable objectListRequirementsSpecification) + { + foreach(var requirementsSpecificationItem in objectListRequirementsSpecification.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ruleverificationlist": + var allowedVersionsForRuleVerificationList = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRuleVerificationList.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("ruleVerificationList"u8); + + if(value is IEnumerable objectListRuleVerificationList) + { + foreach(var ruleVerificationListItem in objectListRuleVerificationList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } + } + + writer.WriteEndArray(); + break; + case "shareddiagramstyle": + var allowedVersionsForSharedDiagramStyle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSharedDiagramStyle.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sharedDiagramStyle"u8); + + if(value is IEnumerable objectListSharedDiagramStyle) + { + foreach(var sharedDiagramStyleItem in objectListSharedDiagramStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sharedDiagramStyleItem); + } + } + + writer.WriteEndArray(); + break; + case "sourceiterationiid": + var allowedVersionsForSourceIterationIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceIterationIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sourceIterationIid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "stakeholder": + var allowedVersionsForStakeholder = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholder.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("stakeholder"u8); + + if(value is IEnumerable objectListStakeholder) + { + foreach(var stakeholderItem in objectListStakeholder.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderItem); + } + } + + writer.WriteEndArray(); + break; + case "stakeholdervalue": + var allowedVersionsForStakeholderValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("stakeholderValue"u8); + + if(value is IEnumerable objectListStakeholderValue) + { + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + } + + writer.WriteEndArray(); + break; + case "stakeholdervaluemap": + var allowedVersionsForStakeholderValueMap = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholderValueMap.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("stakeholderValueMap"u8); + + if(value is IEnumerable objectListStakeholderValueMap) + { + foreach(var stakeholderValueMapItem in objectListStakeholderValueMap.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueMapItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "topelement": + var allowedVersionsForTopElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTopElement.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("topElement"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuegroup": + var allowedVersionsForValueGroup = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueGroup"u8); + + if(value is IEnumerable objectListValueGroup) + { + foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Iteration"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Iteration iteration) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Iteration", nameof(thing)); } - var iteration = thing as Iteration; - if (iteration == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a Iteration."); + Logger.Log(LogLevel.Info, "Skipping serialization of Iteration since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.0.0"); + writer.WriteStartArray("actualFiniteStateList"u8); + + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); + + if(iteration.DefaultOption.HasValue) + { + writer.WriteStringValue(iteration.DefaultOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("domainFileStore"u8); + + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("element"u8); + + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); + + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WriteStartArray("option"u8); + + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relationship"u8); + + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirementsSpecification"u8); + + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); + + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) + { + writer.WriteStringValue(iteration.SourceIterationIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("topElement"u8); + + if(iteration.TopElement.HasValue) + { + writer.WriteStringValue(iteration.TopElement.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.1.0"); + writer.WriteStartArray("actualFiniteStateList"u8); + + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); + + if(iteration.DefaultOption.HasValue) + { + writer.WriteStringValue(iteration.DefaultOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramCanvas"u8); + + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainFileStore"u8); + + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("element"u8); + + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); + + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("option"u8); + + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relationship"u8); + + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirementsSpecification"u8); + + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); + + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sharedDiagramStyle"u8); + + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sharedDiagramStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) + { + writer.WriteStringValue(iteration.SourceIterationIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("stakeholder"u8); + + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValueMap"u8); + + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueMapItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("topElement"u8); + + if(iteration.TopElement.HasValue) + { + writer.WriteStringValue(iteration.TopElement.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.2.0"); + writer.WriteStartArray("actualFiniteStateList"u8); + + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); + + if(iteration.DefaultOption.HasValue) + { + writer.WriteStringValue(iteration.DefaultOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramCanvas"u8); + + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainFileStore"u8); + + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("element"u8); + + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); + + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("option"u8); + + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relationship"u8); + + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirementsSpecification"u8); + + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); + + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sharedDiagramStyle"u8); + + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sharedDiagramStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) + { + writer.WriteStringValue(iteration.SourceIterationIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("stakeholder"u8); + + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValueMap"u8); + + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueMapItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iteration.ThingPreference); + writer.WritePropertyName("topElement"u8); + + if(iteration.TopElement.HasValue) + { + writer.WriteStringValue(iteration.TopElement.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(iteration.Actor.HasValue) + { + writer.WriteStringValue(iteration.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("actualFiniteStateList"u8); + + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); + + if(iteration.DefaultOption.HasValue) + { + writer.WriteStringValue(iteration.DefaultOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramCanvas"u8); + + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainFileStore"u8); + + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("element"u8); + + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); + + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("option"u8); + + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("possibleFiniteStateList"u8); + + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relationship"u8); + + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirementsSpecification"u8); + + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); + + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sharedDiagramStyle"u8); + + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sharedDiagramStyleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) + { + writer.WriteStringValue(iteration.SourceIterationIid.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("stakeholder"u8); + + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("stakeholderValueMap"u8); + + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueMapItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iteration.ThingPreference); + writer.WritePropertyName("topElement"u8); + + if(iteration.TopElement.HasValue) + { + writer.WriteStringValue(iteration.TopElement.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(iteration); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs index b3f98bd3b..5f6ab1369 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using IterationSetup = CDP4Common.DTO.IterationSetup; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,668 @@ namespace CDP4JsonSerializer public class IterationSetupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "description", description => new JValue(description) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "frozenOn", frozenOn => new JValue(frozenOn != null ? ((DateTime)frozenOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ") : null) }, - { "iid", iid => new JValue(iid) }, - { "isDeleted", isDeleted => new JValue(isDeleted) }, - { "iterationIid", iterationIid => new JValue(iterationIid) }, - { "iterationNumber", iterationNumber => new JValue(iterationNumber) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "sourceIterationSetup", sourceIterationSetup => new JValue(sourceIterationSetup) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(IterationSetup iterationSetup) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), iterationSetup.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](iterationSetup.CreatedOn)); - jsonObject.Add("description", this.PropertySerializerMap["description"](iterationSetup.Description)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](iterationSetup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](iterationSetup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("frozenOn", this.PropertySerializerMap["frozenOn"](iterationSetup.FrozenOn)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](iterationSetup.Iid)); - jsonObject.Add("isDeleted", this.PropertySerializerMap["isDeleted"](iterationSetup.IsDeleted)); - jsonObject.Add("iterationIid", this.PropertySerializerMap["iterationIid"](iterationSetup.IterationIid)); - jsonObject.Add("iterationNumber", this.PropertySerializerMap["iterationNumber"](iterationSetup.IterationNumber)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](iterationSetup.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](iterationSetup.RevisionNumber)); - jsonObject.Add("sourceIterationSetup", this.PropertySerializerMap["sourceIterationSetup"](iterationSetup.SourceIterationSetup)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](iterationSetup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "description": + var allowedVersionsForDescription = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDescription.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("description"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "frozenon": + var allowedVersionsForFrozenOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFrozenOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("frozenOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeleted": + var allowedVersionsForIsDeleted = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeleted.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeleted"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iterationiid": + var allowedVersionsForIterationIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIterationIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iterationIid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iterationnumber": + var allowedVersionsForIterationNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIterationNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iterationNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceiterationsetup": + var allowedVersionsForSourceIterationSetup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceIterationSetup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("sourceIterationSetup"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the IterationSetup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not IterationSetup iterationSetup) + { + throw new ArgumentException("The thing shall be a IterationSetup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of IterationSetup since Version is below 1.0.0"); + return; } - var iterationSetup = thing as IterationSetup; - if (iterationSetup == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a IterationSetup."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) + { + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) + { + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) + { + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) + { + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) + { + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) + { + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iterationSetup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(iterationSetup.Actor.HasValue) + { + writer.WriteStringValue(iterationSetup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) + { + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) + { + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iterationSetup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(iterationSetup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs index fd2b705ac..75ef50fd7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using LinearConversionUnit = CDP4Common.DTO.LinearConversionUnit; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,702 @@ namespace CDP4JsonSerializer public class LinearConversionUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "conversionFactor", conversionFactor => new JValue(conversionFactor) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "referenceUnit", referenceUnit => new JValue(referenceUnit) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(LinearConversionUnit linearConversionUnit) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](linearConversionUnit.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), linearConversionUnit.ClassKind))); - jsonObject.Add("conversionFactor", this.PropertySerializerMap["conversionFactor"](linearConversionUnit.ConversionFactor)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](linearConversionUnit.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](linearConversionUnit.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](linearConversionUnit.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](linearConversionUnit.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](linearConversionUnit.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](linearConversionUnit.Name)); - jsonObject.Add("referenceUnit", this.PropertySerializerMap["referenceUnit"](linearConversionUnit.ReferenceUnit)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](linearConversionUnit.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](linearConversionUnit.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](linearConversionUnit.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "conversionfactor": + var allowedVersionsForConversionFactor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForConversionFactor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("conversionFactor"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referenceunit": + var allowedVersionsForReferenceUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referenceUnit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the LinearConversionUnit"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not LinearConversionUnit linearConversionUnit) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a LinearConversionUnit", nameof(thing)); } - var linearConversionUnit = thing as LinearConversionUnit; - if (linearConversionUnit == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a LinearConversionUnit."); + Logger.Log(LogLevel.Info, "Skipping serialization of LinearConversionUnit since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(linearConversionUnit.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(linearConversionUnit.Actor.HasValue) + { + writer.WriteStringValue(linearConversionUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(linearConversionUnit.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(linearConversionUnit); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs index 637d9bbaa..bb2eb50c7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using LogEntryChangelogItem = CDP4Common.DTO.LogEntryChangelogItem; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,440 @@ namespace CDP4JsonSerializer public class LogEntryChangelogItemSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "affectedItemIid", affectedItemIid => new JValue(affectedItemIid) }, - { "affectedReferenceIid", affectedReferenceIid => new JArray(affectedReferenceIid) }, - { "changeDescription", changeDescription => new JValue(changeDescription) }, - { "changelogKind", changelogKind => new JValue(changelogKind.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(LogEntryChangelogItem logEntryChangelogItem) - { - var jsonObject = new JObject(); - jsonObject.Add("affectedItemIid", this.PropertySerializerMap["affectedItemIid"](logEntryChangelogItem.AffectedItemIid)); - jsonObject.Add("affectedReferenceIid", this.PropertySerializerMap["affectedReferenceIid"](logEntryChangelogItem.AffectedReferenceIid.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("changeDescription", this.PropertySerializerMap["changeDescription"](logEntryChangelogItem.ChangeDescription)); - jsonObject.Add("changelogKind", this.PropertySerializerMap["changelogKind"](Enum.GetName(typeof(CDP4Common.CommonData.LogEntryChangelogItemKind), logEntryChangelogItem.ChangelogKind))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), logEntryChangelogItem.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](logEntryChangelogItem.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](logEntryChangelogItem.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](logEntryChangelogItem.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](logEntryChangelogItem.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "affecteditemiid": + var allowedVersionsForAffectedItemIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("affectedItemIid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "affectedreferenceiid": + var allowedVersionsForAffectedReferenceIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedReferenceIid.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("affectedReferenceIid"u8); + + if(value is IEnumerable objectListAffectedReferenceIid) + { + foreach(var affectedReferenceIidItem in objectListAffectedReferenceIid) + { + writer.WriteStringValue((Guid)affectedReferenceIidItem); + } + } + + writer.WriteEndArray(); + break; + case "changedescription": + var allowedVersionsForChangeDescription = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForChangeDescription.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("changeDescription"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "changelogkind": + var allowedVersionsForChangelogKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForChangelogKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("changelogKind"u8); + + if(value != null) + { + writer.WriteStringValue(((LogEntryChangelogItemKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the LogEntryChangelogItem"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not LogEntryChangelogItem logEntryChangelogItem) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a LogEntryChangelogItem", nameof(thing)); } - var logEntryChangelogItem = thing as LogEntryChangelogItem; - if (logEntryChangelogItem == null) + if (requestedDataModelVersion < Version.Parse("1.2.0")) { - throw new InvalidOperationException("The thing is not a LogEntryChangelogItem."); + Logger.Log(LogLevel.Info, "Skipping serialization of LogEntryChangelogItem since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing LogEntryChangelogItem for Version 1.2.0"); + writer.WritePropertyName("affectedItemIid"u8); + writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); + writer.WriteStartArray("affectedReferenceIid"u8); + + foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) + { + writer.WriteStringValue(affectedReferenceIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeDescription"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); + writer.WritePropertyName("changelogKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logEntryChangelogItem.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logEntryChangelogItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing LogEntryChangelogItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(logEntryChangelogItem.Actor.HasValue) + { + writer.WriteStringValue(logEntryChangelogItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("affectedItemIid"u8); + writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); + writer.WriteStartArray("affectedReferenceIid"u8); + + foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) + { + writer.WriteStringValue(affectedReferenceIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("changeDescription"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); + writer.WritePropertyName("changelogKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logEntryChangelogItem.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logEntryChangelogItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(logEntryChangelogItem); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs index fd9e8eb96..efd6a6ffa 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using LogarithmicScale = CDP4Common.DTO.LogarithmicScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,107 +50,1216 @@ namespace CDP4JsonSerializer public class LogarithmicScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "exponent", exponent => new JValue(exponent) }, - { "factor", factor => new JValue(factor) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isMaximumInclusive", isMaximumInclusive => new JValue(isMaximumInclusive) }, - { "isMinimumInclusive", isMinimumInclusive => new JValue(isMinimumInclusive) }, - { "logarithmBase", logarithmBase => new JValue(logarithmBase.ToString()) }, - { "mappingToReferenceScale", mappingToReferenceScale => new JArray(mappingToReferenceScale) }, - { "maximumPermissibleValue", maximumPermissibleValue => new JValue(maximumPermissibleValue) }, - { "minimumPermissibleValue", minimumPermissibleValue => new JValue(minimumPermissibleValue) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "negativeValueConnotation", negativeValueConnotation => new JValue(negativeValueConnotation) }, - { "numberSet", numberSet => new JValue(numberSet.ToString()) }, - { "positiveValueConnotation", positiveValueConnotation => new JValue(positiveValueConnotation) }, - { "referenceQuantityKind", referenceQuantityKind => new JValue(referenceQuantityKind) }, - { "referenceQuantityValue", referenceQuantityValue => new JArray(referenceQuantityValue) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - { "valueDefinition", valueDefinition => new JArray(valueDefinition) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(LogarithmicScale logarithmicScale) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](logarithmicScale.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), logarithmicScale.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](logarithmicScale.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](logarithmicScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](logarithmicScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("exponent", this.PropertySerializerMap["exponent"](logarithmicScale.Exponent)); - jsonObject.Add("factor", this.PropertySerializerMap["factor"](logarithmicScale.Factor)); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](logarithmicScale.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](logarithmicScale.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](logarithmicScale.IsDeprecated)); - jsonObject.Add("isMaximumInclusive", this.PropertySerializerMap["isMaximumInclusive"](logarithmicScale.IsMaximumInclusive)); - jsonObject.Add("isMinimumInclusive", this.PropertySerializerMap["isMinimumInclusive"](logarithmicScale.IsMinimumInclusive)); - jsonObject.Add("logarithmBase", this.PropertySerializerMap["logarithmBase"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.LogarithmBaseKind), logarithmicScale.LogarithmBase))); - jsonObject.Add("mappingToReferenceScale", this.PropertySerializerMap["mappingToReferenceScale"](logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("maximumPermissibleValue", this.PropertySerializerMap["maximumPermissibleValue"](logarithmicScale.MaximumPermissibleValue)); - jsonObject.Add("minimumPermissibleValue", this.PropertySerializerMap["minimumPermissibleValue"](logarithmicScale.MinimumPermissibleValue)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](logarithmicScale.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](logarithmicScale.Name)); - jsonObject.Add("negativeValueConnotation", this.PropertySerializerMap["negativeValueConnotation"](logarithmicScale.NegativeValueConnotation)); - jsonObject.Add("numberSet", this.PropertySerializerMap["numberSet"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.NumberSetKind), logarithmicScale.NumberSet))); - jsonObject.Add("positiveValueConnotation", this.PropertySerializerMap["positiveValueConnotation"](logarithmicScale.PositiveValueConnotation)); - jsonObject.Add("referenceQuantityKind", this.PropertySerializerMap["referenceQuantityKind"](logarithmicScale.ReferenceQuantityKind)); - jsonObject.Add("referenceQuantityValue", this.PropertySerializerMap["referenceQuantityValue"](logarithmicScale.ReferenceQuantityValue)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](logarithmicScale.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](logarithmicScale.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](logarithmicScale.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](logarithmicScale.Unit)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](logarithmicScale.ValueDefinition.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "exponent": + var allowedVersionsForExponent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExponent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("exponent"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "factor": + var allowedVersionsForFactor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFactor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("factor"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + var allowedVersionsForIsMaximumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + var allowedVersionsForIsMinimumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logarithmbase": + var allowedVersionsForLogarithmBase = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLogarithmBase.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("logarithmBase"u8); + + if(value != null) + { + writer.WriteStringValue(((LogarithmBaseKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + var allowedVersionsForMappingToReferenceScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + var allowedVersionsForMaximumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minimumpermissiblevalue": + var allowedVersionsForMinimumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + var allowedVersionsForNegativeValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + var allowedVersionsForNumberSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + var allowedVersionsForPositiveValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencequantitykind": + var allowedVersionsForReferenceQuantityKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceQuantityKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referenceQuantityKind"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencequantityvalue": + var allowedVersionsForReferenceQuantityValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceQuantityValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("referenceQuantityValue"u8); + + if(value is IEnumerable objectListReferenceQuantityValue) + { + foreach(var referenceQuantityValueItem in objectListReferenceQuantityValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceQuantityValueItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the LogarithmicScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not LogarithmicScale logarithmicScale) + { + throw new ArgumentException("The thing shall be a LogarithmicScale", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of LogarithmicScale since Version is below 1.0.0"); + return; } - var logarithmicScale = thing as LogarithmicScale; - if (logarithmicScale == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a LogarithmicScale."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceQuantityValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceQuantityValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceQuantityValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logarithmicScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(logarithmicScale.Actor.HasValue) + { + writer.WriteStringValue(logarithmicScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceQuantityValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logarithmicScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(logarithmicScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs index 6e2726cf5..f5cc23eec 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using MappingToReferenceScale = CDP4Common.DTO.MappingToReferenceScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class MappingToReferenceScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "dependentScaleValue", dependentScaleValue => new JValue(dependentScaleValue) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "referenceScaleValue", referenceScaleValue => new JValue(referenceScaleValue) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(MappingToReferenceScale mappingToReferenceScale) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), mappingToReferenceScale.ClassKind))); - jsonObject.Add("dependentScaleValue", this.PropertySerializerMap["dependentScaleValue"](mappingToReferenceScale.DependentScaleValue)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](mappingToReferenceScale.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](mappingToReferenceScale.ModifiedOn)); - jsonObject.Add("referenceScaleValue", this.PropertySerializerMap["referenceScaleValue"](mappingToReferenceScale.ReferenceScaleValue)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](mappingToReferenceScale.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](mappingToReferenceScale.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "dependentscalevalue": + var allowedVersionsForDependentScaleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDependentScaleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("dependentScaleValue"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencescalevalue": + var allowedVersionsForReferenceScaleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceScaleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referenceScaleValue"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the MappingToReferenceScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not MappingToReferenceScale mappingToReferenceScale) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a MappingToReferenceScale", nameof(thing)); } - var mappingToReferenceScale = thing as MappingToReferenceScale; - if (mappingToReferenceScale == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of MappingToReferenceScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a MappingToReferenceScale."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(mappingToReferenceScale.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(mappingToReferenceScale.Actor.HasValue) + { + writer.WriteStringValue(mappingToReferenceScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(mappingToReferenceScale.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(mappingToReferenceScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs index 7530df8fc..39cf32199 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ModelLogEntry = CDP4Common.DTO.ModelLogEntry; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,778 @@ namespace CDP4JsonSerializer public class ModelLogEntrySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "affectedDomainIid", affectedDomainIid => new JArray(affectedDomainIid) }, - { "affectedItemIid", affectedItemIid => new JArray(affectedItemIid) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "level", level => new JValue(level.ToString()) }, - { "logEntryChangelogItem", logEntryChangelogItem => new JArray(logEntryChangelogItem) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ModelLogEntry modelLogEntry) - { - var jsonObject = new JObject(); - jsonObject.Add("affectedDomainIid", this.PropertySerializerMap["affectedDomainIid"](modelLogEntry.AffectedDomainIid.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("affectedItemIid", this.PropertySerializerMap["affectedItemIid"](modelLogEntry.AffectedItemIid.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](modelLogEntry.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](modelLogEntry.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), modelLogEntry.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](modelLogEntry.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](modelLogEntry.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](modelLogEntry.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](modelLogEntry.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](modelLogEntry.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](modelLogEntry.LanguageCode)); - jsonObject.Add("level", this.PropertySerializerMap["level"](Enum.GetName(typeof(CDP4Common.CommonData.LogLevelKind), modelLogEntry.Level))); - jsonObject.Add("logEntryChangelogItem", this.PropertySerializerMap["logEntryChangelogItem"](modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](modelLogEntry.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](modelLogEntry.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](modelLogEntry.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "affecteddomainiid": + var allowedVersionsForAffectedDomainIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedDomainIid.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("affectedDomainIid"u8); + + if(value is IEnumerable objectListAffectedDomainIid) + { + foreach(var affectedDomainIidItem in objectListAffectedDomainIid) + { + writer.WriteStringValue((Guid)affectedDomainIidItem); + } + } + + writer.WriteEndArray(); + break; + case "affecteditemiid": + var allowedVersionsForAffectedItemIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("affectedItemIid"u8); + + if(value is IEnumerable objectListAffectedItemIid) + { + foreach(var affectedItemIidItem in objectListAffectedItemIid) + { + writer.WriteStringValue((Guid)affectedItemIidItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "level": + var allowedVersionsForLevel = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLevel.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("level"u8); + + if(value != null) + { + writer.WriteStringValue(((LogLevelKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logentrychangelogitem": + var allowedVersionsForLogEntryChangelogItem = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLogEntryChangelogItem.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("logEntryChangelogItem"u8); + + if(value is IEnumerable objectListLogEntryChangelogItem) + { + foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelLogEntry"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ModelLogEntry modelLogEntry) + { + throw new ArgumentException("The thing shall be a ModelLogEntry", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ModelLogEntry since Version is below 1.0.0"); + return; } - var modelLogEntry = thing as ModelLogEntry; - if (modelLogEntry == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ModelLogEntry."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.0.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) + { + writer.WriteStringValue(modelLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.1.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) + { + writer.WriteStringValue(modelLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.2.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) + { + writer.WriteStringValue(modelLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelLogEntry.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modelLogEntry.Actor.HasValue) + { + writer.WriteStringValue(modelLogEntry.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) + { + writer.WriteStringValue(modelLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelLogEntry.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(modelLogEntry); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs index 7819baeda..adee5fa3f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ModelReferenceDataLibrary = CDP4Common.DTO.ModelReferenceDataLibrary; /// /// The purpose of the class is to provide a specific serializer @@ -44,101 +50,1366 @@ namespace CDP4JsonSerializer public class ModelReferenceDataLibrarySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "baseQuantityKind", baseQuantityKind => new JArray(((IEnumerable)baseQuantityKind).Cast().Select(x => x.ToJsonObject())) }, - { "baseUnit", baseUnit => new JArray(baseUnit) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "constant", constant => new JArray(constant) }, - { "definedCategory", definedCategory => new JArray(definedCategory) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fileType", fileType => new JArray(fileType) }, - { "glossary", glossary => new JArray(glossary) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "parameterType", parameterType => new JArray(parameterType) }, - { "referenceSource", referenceSource => new JArray(referenceSource) }, - { "requiredRdl", requiredRdl => new JValue(requiredRdl) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "rule", rule => new JArray(rule) }, - { "scale", scale => new JArray(scale) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JArray(unit) }, - { "unitPrefix", unitPrefix => new JArray(unitPrefix) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ModelReferenceDataLibrary modelReferenceDataLibrary) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](modelReferenceDataLibrary.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("baseQuantityKind", this.PropertySerializerMap["baseQuantityKind"](modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("baseUnit", this.PropertySerializerMap["baseUnit"](modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), modelReferenceDataLibrary.ClassKind))); - jsonObject.Add("constant", this.PropertySerializerMap["constant"](modelReferenceDataLibrary.Constant.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("definedCategory", this.PropertySerializerMap["definedCategory"](modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](modelReferenceDataLibrary.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fileType", this.PropertySerializerMap["fileType"](modelReferenceDataLibrary.FileType.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("glossary", this.PropertySerializerMap["glossary"](modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](modelReferenceDataLibrary.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](modelReferenceDataLibrary.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](modelReferenceDataLibrary.Name)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("referenceSource", this.PropertySerializerMap["referenceSource"](modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("requiredRdl", this.PropertySerializerMap["requiredRdl"](modelReferenceDataLibrary.RequiredRdl)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](modelReferenceDataLibrary.RevisionNumber)); - jsonObject.Add("rule", this.PropertySerializerMap["rule"](modelReferenceDataLibrary.Rule.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](modelReferenceDataLibrary.Scale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](modelReferenceDataLibrary.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](modelReferenceDataLibrary.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](modelReferenceDataLibrary.Unit.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("unitPrefix", this.PropertySerializerMap["unitPrefix"](modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "basequantitykind": + var allowedVersionsForBaseQuantityKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBaseQuantityKind.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("baseQuantityKind"u8); + + if(value is IEnumerable objectListBaseQuantityKind) + { + foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + } + + writer.WriteEndArray(); + break; + case "baseunit": + var allowedVersionsForBaseUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBaseUnit.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("baseUnit"u8); + + if(value is IEnumerable objectListBaseUnit) + { + foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "constant": + var allowedVersionsForConstant = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForConstant.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("constant"u8); + + if(value is IEnumerable objectListConstant) + { + foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + } + + writer.WriteEndArray(); + break; + case "definedcategory": + var allowedVersionsForDefinedCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinedCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definedCategory"u8); + + if(value is IEnumerable objectListDefinedCategory) + { + foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filetype": + var allowedVersionsForFileType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFileType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("fileType"u8); + + if(value is IEnumerable objectListFileType) + { + foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "glossary": + var allowedVersionsForGlossary = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGlossary.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("glossary"u8); + + if(value is IEnumerable objectListGlossary) + { + foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterType"u8); + + if(value is IEnumerable objectListParameterType) + { + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "referencesource": + var allowedVersionsForReferenceSource = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceSource.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("referenceSource"u8); + + if(value is IEnumerable objectListReferenceSource) + { + foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + } + + writer.WriteEndArray(); + break; + case "requiredrdl": + var allowedVersionsForRequiredRdl = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("requiredRdl"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "rule": + var allowedVersionsForRule = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRule.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("rule"u8); + + if(value is IEnumerable objectListRule) + { + foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + } + + writer.WriteEndArray(); + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("scale"u8); + + if(value is IEnumerable objectListScale) + { + foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + } + + writer.WriteEndArray(); + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("unit"u8); + + if(value is IEnumerable objectListUnit) + { + foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + } + + writer.WriteEndArray(); + break; + case "unitprefix": + var allowedVersionsForUnitPrefix = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnitPrefix.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("unitPrefix"u8); + + if(value is IEnumerable objectListUnitPrefix) + { + foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelReferenceDataLibrary"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ModelReferenceDataLibrary modelReferenceDataLibrary) + { + throw new ArgumentException("The thing shall be a ModelReferenceDataLibrary", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ModelReferenceDataLibrary since Version is below 1.0.0"); + return; } - var modelReferenceDataLibrary = thing as ModelReferenceDataLibrary; - if (modelReferenceDataLibrary == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ModelReferenceDataLibrary."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modelReferenceDataLibrary.Actor.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(modelReferenceDataLibrary); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs index b38844db1..35e0bb8a7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ModellingThingReference = CDP4Common.DTO.ModellingThingReference; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,408 @@ namespace CDP4JsonSerializer public class ModellingThingReferenceSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "referencedRevisionNumber", referencedRevisionNumber => new JValue(referencedRevisionNumber) }, - { "referencedThing", referencedThing => new JValue(referencedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ModellingThingReference modellingThingReference) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), modellingThingReference.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](modellingThingReference.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](modellingThingReference.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](modellingThingReference.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](modellingThingReference.ModifiedOn)); - jsonObject.Add("referencedRevisionNumber", this.PropertySerializerMap["referencedRevisionNumber"](modellingThingReference.ReferencedRevisionNumber)); - jsonObject.Add("referencedThing", this.PropertySerializerMap["referencedThing"](modellingThingReference.ReferencedThing)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](modellingThingReference.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](modellingThingReference.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencedrevisionnumber": + var allowedVersionsForReferencedRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referencedRevisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencedthing": + var allowedVersionsForReferencedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referencedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ModellingThingReference"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ModellingThingReference modellingThingReference) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ModellingThingReference", nameof(thing)); } - var modellingThingReference = thing as ModellingThingReference; - if (modellingThingReference == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ModellingThingReference since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ModellingThingReference."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modellingThingReference.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modellingThingReference.Actor.HasValue) + { + writer.WriteStringValue(modellingThingReference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modellingThingReference.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(modellingThingReference); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs index 9b29a1990..d00ea6336 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using MultiRelationshipRule = CDP4Common.DTO.MultiRelationshipRule; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,794 @@ namespace CDP4JsonSerializer public class MultiRelationshipRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "maxRelated", maxRelated => new JValue(maxRelated) }, - { "minRelated", minRelated => new JValue(minRelated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "relatedCategory", relatedCategory => new JArray(relatedCategory) }, - { "relationshipCategory", relationshipCategory => new JValue(relationshipCategory) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(MultiRelationshipRule multiRelationshipRule) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](multiRelationshipRule.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), multiRelationshipRule.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](multiRelationshipRule.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](multiRelationshipRule.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](multiRelationshipRule.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](multiRelationshipRule.IsDeprecated)); - jsonObject.Add("maxRelated", this.PropertySerializerMap["maxRelated"](multiRelationshipRule.MaxRelated)); - jsonObject.Add("minRelated", this.PropertySerializerMap["minRelated"](multiRelationshipRule.MinRelated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](multiRelationshipRule.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](multiRelationshipRule.Name)); - jsonObject.Add("relatedCategory", this.PropertySerializerMap["relatedCategory"](multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("relationshipCategory", this.PropertySerializerMap["relationshipCategory"](multiRelationshipRule.RelationshipCategory)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](multiRelationshipRule.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](multiRelationshipRule.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](multiRelationshipRule.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "maxrelated": + var allowedVersionsForMaxRelated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaxRelated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maxRelated"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minrelated": + var allowedVersionsForMinRelated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinRelated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minRelated"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedcategory": + var allowedVersionsForRelatedCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedCategory"u8); + + if(value is IEnumerable objectListRelatedCategory) + { + foreach(var relatedCategoryItem in objectListRelatedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "relationshipcategory": + var allowedVersionsForRelationshipCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelationshipCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("relationshipCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the MultiRelationshipRule"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not MultiRelationshipRule multiRelationshipRule) + { + throw new ArgumentException("The thing shall be a MultiRelationshipRule", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationshipRule since Version is below 1.0.0"); + return; } - var multiRelationshipRule = thing as MultiRelationshipRule; - if (multiRelationshipRule == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a MultiRelationshipRule."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); + + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); + + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); + + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationshipRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(multiRelationshipRule.Actor.HasValue) + { + writer.WriteStringValue(multiRelationshipRule.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); + + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationshipRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(multiRelationshipRule); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs index 74ec82d50..fb3357b34 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using MultiRelationship = CDP4Common.DTO.MultiRelationship; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,585 @@ namespace CDP4JsonSerializer public class MultiRelationshipSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterValue", parameterValue => new JArray(parameterValue) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(MultiRelationship multiRelationship) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](multiRelationship.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), multiRelationship.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](multiRelationship.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](multiRelationship.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](multiRelationship.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](multiRelationship.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](multiRelationship.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](multiRelationship.Owner)); - jsonObject.Add("parameterValue", this.PropertySerializerMap["parameterValue"](multiRelationship.ParameterValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](multiRelationship.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](multiRelationship.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](multiRelationship.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalue": + var allowedVersionsForParameterValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + + writer.WriteEndArray(); + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the MultiRelationship"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not MultiRelationship multiRelationship) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a MultiRelationship", nameof(thing)); } - var multiRelationship = thing as MultiRelationship; - if (multiRelationship == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a MultiRelationship."); + Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationship since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.0.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationship.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(multiRelationship.Actor.HasValue) + { + writer.WriteStringValue(multiRelationship.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationship.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(multiRelationship); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs index e13e93737..6c4ddc067 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using NaturalLanguage = CDP4Common.DTO.NaturalLanguage; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class NaturalLanguageSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "nativeName", nativeName => new JValue(nativeName) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(NaturalLanguage naturalLanguage) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), naturalLanguage.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](naturalLanguage.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](naturalLanguage.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](naturalLanguage.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](naturalLanguage.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](naturalLanguage.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](naturalLanguage.Name)); - jsonObject.Add("nativeName", this.PropertySerializerMap["nativeName"](naturalLanguage.NativeName)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](naturalLanguage.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](naturalLanguage.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "nativename": + var allowedVersionsForNativeName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNativeName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("nativeName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the NaturalLanguage"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not NaturalLanguage naturalLanguage) + { + throw new ArgumentException("The thing shall be a NaturalLanguage", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of NaturalLanguage since Version is below 1.0.0"); + return; } - var naturalLanguage = thing as NaturalLanguage; - if (naturalLanguage == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a NaturalLanguage."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(naturalLanguage.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(naturalLanguage.Actor.HasValue) + { + writer.WriteStringValue(naturalLanguage.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(naturalLanguage.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(naturalLanguage); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs index 29cf24e9d..25f580cc5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using NestedElement = CDP4Common.DTO.NestedElement; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,542 @@ namespace CDP4JsonSerializer public class NestedElementSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "elementUsage", elementUsage => new JArray(((IEnumerable)elementUsage).Cast().Select(x => x.ToJsonObject())) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isVolatile", isVolatile => new JValue(isVolatile) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "nestedParameter", nestedParameter => new JArray(nestedParameter) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "rootElement", rootElement => new JValue(rootElement) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(NestedElement nestedElement) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), nestedElement.ClassKind))); - jsonObject.Add("elementUsage", this.PropertySerializerMap["elementUsage"](nestedElement.ElementUsage.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](nestedElement.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](nestedElement.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](nestedElement.Iid)); - jsonObject.Add("isVolatile", this.PropertySerializerMap["isVolatile"](nestedElement.IsVolatile)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](nestedElement.ModifiedOn)); - jsonObject.Add("nestedParameter", this.PropertySerializerMap["nestedParameter"](nestedElement.NestedParameter.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](nestedElement.RevisionNumber)); - jsonObject.Add("rootElement", this.PropertySerializerMap["rootElement"](nestedElement.RootElement)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](nestedElement.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "elementusage": + var allowedVersionsForElementUsage = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForElementUsage.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("elementUsage"u8); + + if(value is IEnumerable objectListElementUsage) + { + foreach(var elementUsageItem in objectListElementUsage.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isvolatile": + var allowedVersionsForIsVolatile = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsVolatile.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isVolatile"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "nestedparameter": + var allowedVersionsForNestedParameter = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNestedParameter.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("nestedParameter"u8); + + if(value is IEnumerable objectListNestedParameter) + { + foreach(var nestedParameterItem in objectListNestedParameter.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "rootelement": + var allowedVersionsForRootElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRootElement.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("rootElement"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the NestedElement"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not NestedElement nestedElement) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a NestedElement", nameof(thing)); } - var nestedElement = thing as NestedElement; - if (nestedElement == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a NestedElement."); + Logger.Log(LogLevel.Info, "Skipping serialization of NestedElement since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedElement.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(nestedElement.Actor.HasValue) + { + writer.WriteStringValue(nestedElement.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedElement.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(nestedElement); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs index e77c2355e..a2599bba9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using NestedParameter = CDP4Common.DTO.NestedParameter; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,598 @@ namespace CDP4JsonSerializer public class NestedParameterSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "actualState", actualState => new JValue(actualState) }, - { "actualValue", actualValue => new JValue(actualValue) }, - { "associatedParameter", associatedParameter => new JValue(associatedParameter) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "formula", formula => new JValue(formula) }, - { "iid", iid => new JValue(iid) }, - { "isVolatile", isVolatile => new JValue(isVolatile) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(NestedParameter nestedParameter) - { - var jsonObject = new JObject(); - jsonObject.Add("actualState", this.PropertySerializerMap["actualState"](nestedParameter.ActualState)); - jsonObject.Add("actualValue", this.PropertySerializerMap["actualValue"](nestedParameter.ActualValue)); - jsonObject.Add("associatedParameter", this.PropertySerializerMap["associatedParameter"](nestedParameter.AssociatedParameter)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), nestedParameter.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](nestedParameter.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](nestedParameter.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("formula", this.PropertySerializerMap["formula"](nestedParameter.Formula)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](nestedParameter.Iid)); - jsonObject.Add("isVolatile", this.PropertySerializerMap["isVolatile"](nestedParameter.IsVolatile)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](nestedParameter.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](nestedParameter.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](nestedParameter.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](nestedParameter.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualstate": + var allowedVersionsForActualState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualState.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualState"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualvalue": + var allowedVersionsForActualValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "associatedparameter": + var allowedVersionsForAssociatedParameter = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAssociatedParameter.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("associatedParameter"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "formula": + var allowedVersionsForFormula = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFormula.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("formula"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isvolatile": + var allowedVersionsForIsVolatile = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsVolatile.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isVolatile"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the NestedParameter"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not NestedParameter nestedParameter) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a NestedParameter", nameof(thing)); } - var nestedParameter = thing as NestedParameter; - if (nestedParameter == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a NestedParameter."); + Logger.Log(LogLevel.Info, "Skipping serialization of NestedParameter since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.0.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.1.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.2.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedParameter.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(nestedParameter.Actor.HasValue) + { + writer.WriteStringValue(nestedParameter.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedParameter.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(nestedParameter); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs index 72bc8ad78..46c14ccad 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using NotExpression = CDP4Common.DTO.NotExpression; /// /// The purpose of the class is to provide a specific serializer @@ -44,67 +50,392 @@ namespace CDP4JsonSerializer public class NotExpressionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "term", term => new JValue(term) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(NotExpression notExpression) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), notExpression.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](notExpression.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](notExpression.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](notExpression.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](notExpression.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](notExpression.RevisionNumber)); - jsonObject.Add("term", this.PropertySerializerMap["term"](notExpression.Term)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](notExpression.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "term": + var allowedVersionsForTerm = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTerm.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("term"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the NotExpression"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not NotExpression notExpression) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a NotExpression", nameof(thing)); } - var notExpression = thing as NotExpression; - if (notExpression == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a NotExpression."); + Logger.Log(LogLevel.Info, "Skipping serialization of NotExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(notExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(notExpression.Actor.HasValue) + { + writer.WriteStringValue(notExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(notExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(notExpression); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs index b0aac8817..2dbb091a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Option = CDP4Common.DTO.Option; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,716 @@ namespace CDP4JsonSerializer public class OptionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "nestedElement", nestedElement => new JArray(nestedElement) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Option option) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](option.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](option.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), option.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](option.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](option.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](option.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](option.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](option.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](option.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](option.Name)); - jsonObject.Add("nestedElement", this.PropertySerializerMap["nestedElement"](option.NestedElement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](option.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](option.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](option.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "nestedelement": + var allowedVersionsForNestedElement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNestedElement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("nestedElement"u8); + + if(value is IEnumerable objectListNestedElement) + { + foreach(var nestedElementItem in objectListNestedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Option"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Option option) + { + throw new ArgumentException("The thing shall be a Option", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Option since Version is below 1.0.0"); + return; } - var option = thing as Option; - if (option == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Option."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); + + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); + + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); + + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(option.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(option.Actor.HasValue) + { + writer.WriteStringValue(option.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); + + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(option.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(option); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs index d9b03f282..923a18674 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using OrExpression = CDP4Common.DTO.OrExpression; /// /// The purpose of the class is to provide a specific serializer @@ -44,67 +50,416 @@ namespace CDP4JsonSerializer public class OrExpressionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "term", term => new JArray(term) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(OrExpression orExpression) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), orExpression.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](orExpression.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](orExpression.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](orExpression.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](orExpression.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](orExpression.RevisionNumber)); - jsonObject.Add("term", this.PropertySerializerMap["term"](orExpression.Term.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](orExpression.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "term": + var allowedVersionsForTerm = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTerm.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("term"u8); + + if(value is IEnumerable objectListTerm) + { + foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the OrExpression"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not OrExpression orExpression) + { + throw new ArgumentException("The thing shall be a OrExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of OrExpression since Version is below 1.0.0"); + return; } - var orExpression = thing as OrExpression; - if (orExpression == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a OrExpression."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(orExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(orExpression.Actor.HasValue) + { + writer.WriteStringValue(orExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(orExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(orExpression); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs index 06617a650..621dc57aa 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using OrdinalScale = CDP4Common.DTO.OrdinalScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,99 +50,1056 @@ namespace CDP4JsonSerializer public class OrdinalScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isMaximumInclusive", isMaximumInclusive => new JValue(isMaximumInclusive) }, - { "isMinimumInclusive", isMinimumInclusive => new JValue(isMinimumInclusive) }, - { "mappingToReferenceScale", mappingToReferenceScale => new JArray(mappingToReferenceScale) }, - { "maximumPermissibleValue", maximumPermissibleValue => new JValue(maximumPermissibleValue) }, - { "minimumPermissibleValue", minimumPermissibleValue => new JValue(minimumPermissibleValue) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "negativeValueConnotation", negativeValueConnotation => new JValue(negativeValueConnotation) }, - { "numberSet", numberSet => new JValue(numberSet.ToString()) }, - { "positiveValueConnotation", positiveValueConnotation => new JValue(positiveValueConnotation) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - { "useShortNameValues", useShortNameValues => new JValue(useShortNameValues) }, - { "valueDefinition", valueDefinition => new JArray(valueDefinition) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(OrdinalScale ordinalScale) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](ordinalScale.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), ordinalScale.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](ordinalScale.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](ordinalScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](ordinalScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](ordinalScale.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](ordinalScale.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](ordinalScale.IsDeprecated)); - jsonObject.Add("isMaximumInclusive", this.PropertySerializerMap["isMaximumInclusive"](ordinalScale.IsMaximumInclusive)); - jsonObject.Add("isMinimumInclusive", this.PropertySerializerMap["isMinimumInclusive"](ordinalScale.IsMinimumInclusive)); - jsonObject.Add("mappingToReferenceScale", this.PropertySerializerMap["mappingToReferenceScale"](ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("maximumPermissibleValue", this.PropertySerializerMap["maximumPermissibleValue"](ordinalScale.MaximumPermissibleValue)); - jsonObject.Add("minimumPermissibleValue", this.PropertySerializerMap["minimumPermissibleValue"](ordinalScale.MinimumPermissibleValue)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](ordinalScale.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](ordinalScale.Name)); - jsonObject.Add("negativeValueConnotation", this.PropertySerializerMap["negativeValueConnotation"](ordinalScale.NegativeValueConnotation)); - jsonObject.Add("numberSet", this.PropertySerializerMap["numberSet"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.NumberSetKind), ordinalScale.NumberSet))); - jsonObject.Add("positiveValueConnotation", this.PropertySerializerMap["positiveValueConnotation"](ordinalScale.PositiveValueConnotation)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](ordinalScale.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](ordinalScale.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](ordinalScale.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](ordinalScale.Unit)); - jsonObject.Add("useShortNameValues", this.PropertySerializerMap["useShortNameValues"](ordinalScale.UseShortNameValues)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](ordinalScale.ValueDefinition.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + var allowedVersionsForIsMaximumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + var allowedVersionsForIsMinimumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + var allowedVersionsForMappingToReferenceScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + var allowedVersionsForMaximumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minimumpermissiblevalue": + var allowedVersionsForMinimumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + var allowedVersionsForNegativeValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + var allowedVersionsForNumberSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + var allowedVersionsForPositiveValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "useshortnamevalues": + var allowedVersionsForUseShortNameValues = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUseShortNameValues.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("useShortNameValues"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the OrdinalScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not OrdinalScale ordinalScale) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a OrdinalScale", nameof(thing)); } - var ordinalScale = thing as OrdinalScale; - if (ordinalScale == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a OrdinalScale."); + Logger.Log(LogLevel.Info, "Skipping serialization of OrdinalScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ordinalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ordinalScale.Actor.HasValue) + { + writer.WriteStringValue(ordinalScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ordinalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(ordinalScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs index 82eb0eff5..9a6f7b740 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Organization = CDP4Common.DTO.Organization; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class OrganizationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Organization organization) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), organization.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](organization.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](organization.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](organization.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](organization.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](organization.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](organization.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](organization.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](organization.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](organization.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Organization"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Organization organization) + { + throw new ArgumentException("The thing shall be a Organization", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Organization since Version is below 1.0.0"); + return; } - var organization = thing as Organization; - if (organization == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Organization."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organization.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(organization.Actor.HasValue) + { + writer.WriteStringValue(organization.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organization.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(organization); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs index 5c243593b..a5664db18 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using OrganizationalParticipant = CDP4Common.DTO.OrganizationalParticipant; /// /// The purpose of the class is to provide a specific serializer @@ -44,67 +50,344 @@ namespace CDP4JsonSerializer public class OrganizationalParticipantSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "organization", organization => new JValue(organization) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(OrganizationalParticipant organizationalParticipant) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), organizationalParticipant.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](organizationalParticipant.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](organizationalParticipant.ModifiedOn)); - jsonObject.Add("organization", this.PropertySerializerMap["organization"](organizationalParticipant.Organization)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](organizationalParticipant.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](organizationalParticipant.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "organization": + var allowedVersionsForOrganization = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganization.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("organization"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the OrganizationalParticipant"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not OrganizationalParticipant organizationalParticipant) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a OrganizationalParticipant", nameof(thing)); } - var organizationalParticipant = thing as OrganizationalParticipant; - if (organizationalParticipant == null) + if (requestedDataModelVersion < Version.Parse("1.2.0")) { - throw new InvalidOperationException("The thing is not a OrganizationalParticipant."); + Logger.Log(LogLevel.Info, "Skipping serialization of OrganizationalParticipant since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing OrganizationalParticipant for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organizationalParticipant.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + writer.WriteStringValue(organizationalParticipant.Organization); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organizationalParticipant.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organizationalParticipant.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing OrganizationalParticipant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(organizationalParticipant.Actor.HasValue) + { + writer.WriteStringValue(organizationalParticipant.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organizationalParticipant.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + writer.WriteStringValue(organizationalParticipant.Organization); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organizationalParticipant.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organizationalParticipant.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(organizationalParticipant); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs index 89b636826..ceb911321 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using OwnedStyle = CDP4Common.DTO.OwnedStyle; /// /// The purpose of the class is to provide a specific serializer @@ -44,93 +50,1095 @@ namespace CDP4JsonSerializer public class OwnedStyleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fillColor", fillColor => new JValue(fillColor) }, - { "fillOpacity", fillOpacity => new JValue(fillOpacity) }, - { "fontBold", fontBold => new JValue(fontBold) }, - { "fontColor", fontColor => new JValue(fontColor) }, - { "fontItalic", fontItalic => new JValue(fontItalic) }, - { "fontName", fontName => new JValue(fontName) }, - { "fontSize", fontSize => new JValue(fontSize) }, - { "fontStrokeThrough", fontStrokeThrough => new JValue(fontStrokeThrough) }, - { "fontUnderline", fontUnderline => new JValue(fontUnderline) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "strokeColor", strokeColor => new JValue(strokeColor) }, - { "strokeOpacity", strokeOpacity => new JValue(strokeOpacity) }, - { "strokeWidth", strokeWidth => new JValue(strokeWidth) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "usedColor", usedColor => new JArray(usedColor) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(OwnedStyle ownedStyle) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), ownedStyle.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](ownedStyle.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](ownedStyle.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fillColor", this.PropertySerializerMap["fillColor"](ownedStyle.FillColor)); - jsonObject.Add("fillOpacity", this.PropertySerializerMap["fillOpacity"](ownedStyle.FillOpacity)); - jsonObject.Add("fontBold", this.PropertySerializerMap["fontBold"](ownedStyle.FontBold)); - jsonObject.Add("fontColor", this.PropertySerializerMap["fontColor"](ownedStyle.FontColor)); - jsonObject.Add("fontItalic", this.PropertySerializerMap["fontItalic"](ownedStyle.FontItalic)); - jsonObject.Add("fontName", this.PropertySerializerMap["fontName"](ownedStyle.FontName)); - jsonObject.Add("fontSize", this.PropertySerializerMap["fontSize"](ownedStyle.FontSize)); - jsonObject.Add("fontStrokeThrough", this.PropertySerializerMap["fontStrokeThrough"](ownedStyle.FontStrokeThrough)); - jsonObject.Add("fontUnderline", this.PropertySerializerMap["fontUnderline"](ownedStyle.FontUnderline)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](ownedStyle.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](ownedStyle.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](ownedStyle.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](ownedStyle.RevisionNumber)); - jsonObject.Add("strokeColor", this.PropertySerializerMap["strokeColor"](ownedStyle.StrokeColor)); - jsonObject.Add("strokeOpacity", this.PropertySerializerMap["strokeOpacity"](ownedStyle.StrokeOpacity)); - jsonObject.Add("strokeWidth", this.PropertySerializerMap["strokeWidth"](ownedStyle.StrokeWidth)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](ownedStyle.ThingPreference)); - jsonObject.Add("usedColor", this.PropertySerializerMap["usedColor"](ownedStyle.UsedColor.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "fillcolor": + var allowedVersionsForFillColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFillColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fillopacity": + var allowedVersionsForFillOpacity = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFillOpacity.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillOpacity"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontbold": + var allowedVersionsForFontBold = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontBold.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontBold"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontcolor": + var allowedVersionsForFontColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontitalic": + var allowedVersionsForFontItalic = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontItalic.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontItalic"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontname": + var allowedVersionsForFontName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontsize": + var allowedVersionsForFontSize = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontSize.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontSize"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontstrokethrough": + var allowedVersionsForFontStrokeThrough = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontStrokeThrough.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontunderline": + var allowedVersionsForFontUnderline = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontUnderline.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontUnderline"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokecolor": + var allowedVersionsForStrokeColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokeopacity": + var allowedVersionsForStrokeOpacity = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeOpacity.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokewidth": + var allowedVersionsForStrokeWidth = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeWidth.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeWidth"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "usedcolor": + var allowedVersionsForUsedColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUsedColor.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("usedColor"u8); + + if(value is IEnumerable objectListUsedColor) + { + foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the OwnedStyle"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not OwnedStyle ownedStyle) + { + throw new ArgumentException("The thing shall be a OwnedStyle", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of OwnedStyle since Version is below 1.1.0"); + return; } - var ownedStyle = thing as OwnedStyle; - if (ownedStyle == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a OwnedStyle."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ownedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ownedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(ownedStyle.FillColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(ownedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(ownedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(ownedStyle.FontColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(ownedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(ownedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(ownedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(ownedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(ownedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(ownedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ownedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ownedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ownedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(ownedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(ownedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(ownedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(ownedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ownedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ownedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(ownedStyle.FillColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(ownedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(ownedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(ownedStyle.FontColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(ownedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(ownedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(ownedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(ownedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(ownedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(ownedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ownedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ownedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ownedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(ownedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(ownedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(ownedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(ownedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ownedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ownedStyle.Actor.HasValue) + { + writer.WriteStringValue(ownedStyle.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ownedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ownedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(ownedStyle.FillColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(ownedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(ownedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(ownedStyle.FontColor.HasValue) + { + writer.WriteStringValue(ownedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(ownedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(ownedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(ownedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(ownedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(ownedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(ownedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ownedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ownedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ownedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(ownedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(ownedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(ownedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(ownedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ownedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(ownedStyle); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs index 7b64c8b86..cef6bb6db 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Page = CDP4Common.DTO.Page; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,568 @@ namespace CDP4JsonSerializer public class PageSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "note", note => new JArray(((IEnumerable)note).Cast().Select(x => x.ToJsonObject())) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Page page) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](page.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), page.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](page.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](page.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](page.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](page.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](page.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](page.Name)); - jsonObject.Add("note", this.PropertySerializerMap["note"](page.Note.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](page.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](page.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](page.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](page.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "note": + var allowedVersionsForNote = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNote.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("note"u8); + + if(value is IEnumerable objectListNote) + { + foreach(var noteItem in objectListNote.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + } + + writer.WriteEndArray(); + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Page"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Page page) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Page", nameof(thing)); } - var page = thing as Page; - if (page == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a Page."); + Logger.Log(LogLevel.Info, "Skipping serialization of Page since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(page.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(page.Actor.HasValue) + { + writer.WriteStringValue(page.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(page.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(page); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs index 35afbca65..d2bb26180 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterGroup = CDP4Common.DTO.ParameterGroup; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,462 @@ namespace CDP4JsonSerializer public class ParameterGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "containingGroup", containingGroup => new JValue(containingGroup) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterGroup parameterGroup) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterGroup.ClassKind))); - jsonObject.Add("containingGroup", this.PropertySerializerMap["containingGroup"](parameterGroup.ContainingGroup)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterGroup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterGroup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterGroup.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterGroup.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](parameterGroup.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterGroup.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterGroup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "containinggroup": + var allowedVersionsForContainingGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContainingGroup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("containingGroup"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterGroup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterGroup parameterGroup) + { + throw new ArgumentException("The thing shall be a ParameterGroup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterGroup since Version is below 1.0.0"); + return; } - var parameterGroup = thing as ParameterGroup; - if (parameterGroup == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParameterGroup."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterGroup.Actor.HasValue) + { + writer.WriteStringValue(parameterGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterGroup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs index 8b5e7424a..7746b5d07 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterOverride = CDP4Common.DTO.ParameterOverride; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,542 @@ namespace CDP4JsonSerializer public class ParameterOverrideSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "parameter", parameter => new JValue(parameter) }, - { "parameterSubscription", parameterSubscription => new JArray(parameterSubscription) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSet", valueSet => new JArray(valueSet) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterOverride parameterOverride) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterOverride.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterOverride.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterOverride.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterOverride.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterOverride.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](parameterOverride.Owner)); - jsonObject.Add("parameter", this.PropertySerializerMap["parameter"](parameterOverride.Parameter)); - jsonObject.Add("parameterSubscription", this.PropertySerializerMap["parameterSubscription"](parameterOverride.ParameterSubscription.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterOverride.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterOverride.ThingPreference)); - jsonObject.Add("valueSet", this.PropertySerializerMap["valueSet"](parameterOverride.ValueSet.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parameter": + var allowedVersionsForParameter = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameter.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameter"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametersubscription": + var allowedVersionsForParameterSubscription = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterSubscription.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterSubscription"u8); + + if(value is IEnumerable objectListParameterSubscription) + { + foreach(var parameterSubscriptionItem in objectListParameterSubscription.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueset": + var allowedVersionsForValueSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSet.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueSet"u8); + + if(value is IEnumerable objectListValueSet) + { + foreach(var valueSetItem in objectListValueSet.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterOverride"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterOverride parameterOverride) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParameterOverride", nameof(thing)); } - var parameterOverride = thing as ParameterOverride; - if (parameterOverride == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ParameterOverride."); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverride since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverride.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterOverride.Actor.HasValue) + { + writer.WriteStringValue(parameterOverride.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverride.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterOverride); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs index 71f0c2ff0..2cfd1c470 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterOverrideValueSet = CDP4Common.DTO.ParameterOverrideValueSet; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,526 @@ namespace CDP4JsonSerializer public class ParameterOverrideValueSetSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "computed", computed => new JValue(((ValueArray)computed).ToJsonString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "formula", formula => new JValue(((ValueArray)formula).ToJsonString()) }, - { "iid", iid => new JValue(iid) }, - { "manual", manual => new JValue(((ValueArray)manual).ToJsonString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterValueSet", parameterValueSet => new JValue(parameterValueSet) }, - { "published", published => new JValue(((ValueArray)published).ToJsonString()) }, - { "reference", reference => new JValue(((ValueArray)reference).ToJsonString()) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSwitch", valueSwitch => new JValue(valueSwitch.ToString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterOverrideValueSet parameterOverrideValueSet) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterOverrideValueSet.ClassKind))); - jsonObject.Add("computed", this.PropertySerializerMap["computed"](parameterOverrideValueSet.Computed)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("formula", this.PropertySerializerMap["formula"](parameterOverrideValueSet.Formula)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterOverrideValueSet.Iid)); - jsonObject.Add("manual", this.PropertySerializerMap["manual"](parameterOverrideValueSet.Manual)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterOverrideValueSet.ModifiedOn)); - jsonObject.Add("parameterValueSet", this.PropertySerializerMap["parameterValueSet"](parameterOverrideValueSet.ParameterValueSet)); - jsonObject.Add("published", this.PropertySerializerMap["published"](parameterOverrideValueSet.Published)); - jsonObject.Add("reference", this.PropertySerializerMap["reference"](parameterOverrideValueSet.Reference)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterOverrideValueSet.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterOverrideValueSet.ThingPreference)); - jsonObject.Add("valueSwitch", this.PropertySerializerMap["valueSwitch"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.ParameterSwitchKind), parameterOverrideValueSet.ValueSwitch))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "computed": + var allowedVersionsForComputed = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForComputed.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("computed"u8, ((ValueArray)value).ToJsonString()); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "formula": + var allowedVersionsForFormula = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFormula.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("formula"u8, ((ValueArray)value).ToJsonString()); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "manual": + var allowedVersionsForManual = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForManual.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalueset": + var allowedVersionsForParameterValueSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValueSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterValueSet"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "published": + var allowedVersionsForPublished = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublished.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("published"u8, ((ValueArray)value).ToJsonString()); + break; + case "reference": + var allowedVersionsForReference = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReference.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("reference"u8, ((ValueArray)value).ToJsonString()); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueswitch": + var allowedVersionsForValueSwitch = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueSwitch"u8); + + if(value != null) + { + writer.WriteStringValue(((ParameterSwitchKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterOverrideValueSet"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterOverrideValueSet parameterOverrideValueSet) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParameterOverrideValueSet", nameof(thing)); } - var parameterOverrideValueSet = thing as ParameterOverrideValueSet; - if (parameterOverrideValueSet == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ParameterOverrideValueSet."); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverrideValueSet since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterOverrideValueSet.Actor.HasValue) + { + writer.WriteStringValue(parameterOverrideValueSet.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterOverrideValueSet); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs index a2bbf5247..e9929f62a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Parameter = CDP4Common.DTO.Parameter; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,924 @@ namespace CDP4JsonSerializer public class ParameterSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "allowDifferentOwnerOfOverride", allowDifferentOwnerOfOverride => new JValue(allowDifferentOwnerOfOverride) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "expectsOverride", expectsOverride => new JValue(expectsOverride) }, - { "group", group => new JValue(group) }, - { "iid", iid => new JValue(iid) }, - { "isOptionDependent", isOptionDependent => new JValue(isOptionDependent) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "parameterSubscription", parameterSubscription => new JArray(parameterSubscription) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "requestedBy", requestedBy => new JValue(requestedBy) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "stateDependence", stateDependence => new JValue(stateDependence) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSet", valueSet => new JArray(valueSet) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Parameter parameter) - { - var jsonObject = new JObject(); - jsonObject.Add("allowDifferentOwnerOfOverride", this.PropertySerializerMap["allowDifferentOwnerOfOverride"](parameter.AllowDifferentOwnerOfOverride)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameter.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameter.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameter.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("expectsOverride", this.PropertySerializerMap["expectsOverride"](parameter.ExpectsOverride)); - jsonObject.Add("group", this.PropertySerializerMap["group"](parameter.Group)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameter.Iid)); - jsonObject.Add("isOptionDependent", this.PropertySerializerMap["isOptionDependent"](parameter.IsOptionDependent)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameter.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](parameter.Owner)); - jsonObject.Add("parameterSubscription", this.PropertySerializerMap["parameterSubscription"](parameter.ParameterSubscription.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](parameter.ParameterType)); - jsonObject.Add("requestedBy", this.PropertySerializerMap["requestedBy"](parameter.RequestedBy)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameter.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](parameter.Scale)); - jsonObject.Add("stateDependence", this.PropertySerializerMap["stateDependence"](parameter.StateDependence)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameter.ThingPreference)); - jsonObject.Add("valueSet", this.PropertySerializerMap["valueSet"](parameter.ValueSet.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "allowdifferentownerofoverride": + var allowedVersionsForAllowDifferentOwnerOfOverride = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAllowDifferentOwnerOfOverride.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "expectsoverride": + var allowedVersionsForExpectsOverride = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExpectsOverride.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("expectsOverride"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "group": + var allowedVersionsForGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGroup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("group"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isoptiondependent": + var allowedVersionsForIsOptionDependent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsOptionDependent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isOptionDependent"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametersubscription": + var allowedVersionsForParameterSubscription = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterSubscription.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterSubscription"u8); + + if(value is IEnumerable objectListParameterSubscription) + { + foreach(var parameterSubscriptionItem in objectListParameterSubscription.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + } + + writer.WriteEndArray(); + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "requestedby": + var allowedVersionsForRequestedBy = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequestedBy.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("requestedBy"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "statedependence": + var allowedVersionsForStateDependence = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStateDependence.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("stateDependence"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueset": + var allowedVersionsForValueSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSet.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueSet"u8); + + if(value is IEnumerable objectListValueSet) + { + foreach(var valueSetItem in objectListValueSet.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Parameter"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Parameter parameter) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Parameter", nameof(thing)); } - var parameter = thing as Parameter; - if (parameter == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a Parameter."); + Logger.Log(LogLevel.Info, "Skipping serialization of Parameter since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.0.0"); + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) + { + writer.WriteStringValue(parameter.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); + writer.WritePropertyName("requestedBy"u8); + + if(parameter.RequestedBy.HasValue) + { + writer.WriteStringValue(parameter.RequestedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameter.Scale.HasValue) + { + writer.WriteStringValue(parameter.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("stateDependence"u8); + + if(parameter.StateDependence.HasValue) + { + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.1.0"); + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) + { + writer.WriteStringValue(parameter.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); + writer.WritePropertyName("requestedBy"u8); + + if(parameter.RequestedBy.HasValue) + { + writer.WriteStringValue(parameter.RequestedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameter.Scale.HasValue) + { + writer.WriteStringValue(parameter.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("stateDependence"u8); + + if(parameter.StateDependence.HasValue) + { + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.2.0"); + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) + { + writer.WriteStringValue(parameter.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); + writer.WritePropertyName("requestedBy"u8); + + if(parameter.RequestedBy.HasValue) + { + writer.WriteStringValue(parameter.RequestedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameter.Scale.HasValue) + { + writer.WriteStringValue(parameter.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("stateDependence"u8); + + if(parameter.StateDependence.HasValue) + { + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameter.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameter.Actor.HasValue) + { + writer.WriteStringValue(parameter.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) + { + writer.WriteStringValue(parameter.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); + writer.WritePropertyName("requestedBy"u8); + + if(parameter.RequestedBy.HasValue) + { + writer.WriteStringValue(parameter.RequestedBy.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameter.Scale.HasValue) + { + writer.WriteStringValue(parameter.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("stateDependence"u8); + + if(parameter.StateDependence.HasValue) + { + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameter.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameter); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs index 392720421..31ec83387 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterSubscription = CDP4Common.DTO.ParameterSubscription; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,450 @@ namespace CDP4JsonSerializer public class ParameterSubscriptionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSet", valueSet => new JArray(valueSet) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterSubscription parameterSubscription) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterSubscription.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterSubscription.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterSubscription.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterSubscription.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterSubscription.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](parameterSubscription.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterSubscription.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterSubscription.ThingPreference)); - jsonObject.Add("valueSet", this.PropertySerializerMap["valueSet"](parameterSubscription.ValueSet.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueset": + var allowedVersionsForValueSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSet.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueSet"u8); + + if(value is IEnumerable objectListValueSet) + { + foreach(var valueSetItem in objectListValueSet.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterSubscription"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterSubscription parameterSubscription) + { + throw new ArgumentException("The thing shall be a ParameterSubscription", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscription since Version is below 1.0.0"); + return; } - var parameterSubscription = thing as ParameterSubscription; - if (parameterSubscription == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParameterSubscription."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscription.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterSubscription.Actor.HasValue) + { + writer.WriteStringValue(parameterSubscription.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscription.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterSubscription); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs index a2a9afc19..3234ca5c1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterSubscriptionValueSet = CDP4Common.DTO.ParameterSubscriptionValueSet; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,446 @@ namespace CDP4JsonSerializer public class ParameterSubscriptionValueSetSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "manual", manual => new JValue(((ValueArray)manual).ToJsonString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "subscribedValueSet", subscribedValueSet => new JValue(subscribedValueSet) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSwitch", valueSwitch => new JValue(valueSwitch.ToString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterSubscriptionValueSet parameterSubscriptionValueSet) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterSubscriptionValueSet.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterSubscriptionValueSet.Iid)); - jsonObject.Add("manual", this.PropertySerializerMap["manual"](parameterSubscriptionValueSet.Manual)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterSubscriptionValueSet.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterSubscriptionValueSet.RevisionNumber)); - jsonObject.Add("subscribedValueSet", this.PropertySerializerMap["subscribedValueSet"](parameterSubscriptionValueSet.SubscribedValueSet)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterSubscriptionValueSet.ThingPreference)); - jsonObject.Add("valueSwitch", this.PropertySerializerMap["valueSwitch"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.ParameterSwitchKind), parameterSubscriptionValueSet.ValueSwitch))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "manual": + var allowedVersionsForManual = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForManual.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "subscribedvalueset": + var allowedVersionsForSubscribedValueSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSubscribedValueSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("subscribedValueSet"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueswitch": + var allowedVersionsForValueSwitch = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueSwitch"u8); + + if(value != null) + { + writer.WriteStringValue(((ParameterSwitchKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterSubscriptionValueSet"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterSubscriptionValueSet parameterSubscriptionValueSet) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParameterSubscriptionValueSet", nameof(thing)); } - var parameterSubscriptionValueSet = thing as ParameterSubscriptionValueSet; - if (parameterSubscriptionValueSet == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscriptionValueSet since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParameterSubscriptionValueSet."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterSubscriptionValueSet.Actor.HasValue) + { + writer.WriteStringValue(parameterSubscriptionValueSet.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterSubscriptionValueSet); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs index 71a29a208..173e8bc3a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterTypeComponent = CDP4Common.DTO.ParameterTypeComponent; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,496 @@ namespace CDP4JsonSerializer public class ParameterTypeComponentSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterTypeComponent parameterTypeComponent) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterTypeComponent.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterTypeComponent.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterTypeComponent.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](parameterTypeComponent.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterTypeComponent.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](parameterTypeComponent.Scale)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](parameterTypeComponent.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterTypeComponent.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterTypeComponent"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterTypeComponent parameterTypeComponent) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParameterTypeComponent", nameof(thing)); } - var parameterTypeComponent = thing as ParameterTypeComponent; - if (parameterTypeComponent == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ParameterTypeComponent."); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterTypeComponent since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterTypeComponent.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterTypeComponent.Actor.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterTypeComponent.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterTypeComponent); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs index 1bb18011f..6ffcd74d7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterValueSet = CDP4Common.DTO.ParameterValueSet; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,632 @@ namespace CDP4JsonSerializer public class ParameterValueSetSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "actualOption", actualOption => new JValue(actualOption) }, - { "actualState", actualState => new JValue(actualState) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "computed", computed => new JValue(((ValueArray)computed).ToJsonString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "formula", formula => new JValue(((ValueArray)formula).ToJsonString()) }, - { "iid", iid => new JValue(iid) }, - { "manual", manual => new JValue(((ValueArray)manual).ToJsonString()) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "published", published => new JValue(((ValueArray)published).ToJsonString()) }, - { "reference", reference => new JValue(((ValueArray)reference).ToJsonString()) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueSwitch", valueSwitch => new JValue(valueSwitch.ToString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterValueSet parameterValueSet) - { - var jsonObject = new JObject(); - jsonObject.Add("actualOption", this.PropertySerializerMap["actualOption"](parameterValueSet.ActualOption)); - jsonObject.Add("actualState", this.PropertySerializerMap["actualState"](parameterValueSet.ActualState)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterValueSet.ClassKind))); - jsonObject.Add("computed", this.PropertySerializerMap["computed"](parameterValueSet.Computed)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterValueSet.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterValueSet.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("formula", this.PropertySerializerMap["formula"](parameterValueSet.Formula)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterValueSet.Iid)); - jsonObject.Add("manual", this.PropertySerializerMap["manual"](parameterValueSet.Manual)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterValueSet.ModifiedOn)); - jsonObject.Add("published", this.PropertySerializerMap["published"](parameterValueSet.Published)); - jsonObject.Add("reference", this.PropertySerializerMap["reference"](parameterValueSet.Reference)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterValueSet.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterValueSet.ThingPreference)); - jsonObject.Add("valueSwitch", this.PropertySerializerMap["valueSwitch"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.ParameterSwitchKind), parameterValueSet.ValueSwitch))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualoption": + var allowedVersionsForActualOption = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualOption.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualOption"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualstate": + var allowedVersionsForActualState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForActualState.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualState"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "computed": + var allowedVersionsForComputed = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForComputed.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("computed"u8, ((ValueArray)value).ToJsonString()); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "formula": + var allowedVersionsForFormula = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFormula.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("formula"u8, ((ValueArray)value).ToJsonString()); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "manual": + var allowedVersionsForManual = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForManual.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "published": + var allowedVersionsForPublished = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublished.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("published"u8, ((ValueArray)value).ToJsonString()); + break; + case "reference": + var allowedVersionsForReference = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReference.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("reference"u8, ((ValueArray)value).ToJsonString()); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueswitch": + var allowedVersionsForValueSwitch = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueSwitch"u8); + + if(value != null) + { + writer.WriteStringValue(((ParameterSwitchKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterValueSet"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterValueSet parameterValueSet) + { + throw new ArgumentException("The thing shall be a ParameterValueSet", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterValueSet since Version is below 1.0.0"); + return; } - var parameterValueSet = thing as ParameterValueSet; - if (parameterValueSet == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParameterValueSet."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.0.0"); + writer.WritePropertyName("actualOption"u8); + + if(parameterValueSet.ActualOption.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(parameterValueSet.ActualState.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterValueSet.Computed.ToJsonString()); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterValueSet.Iid); + writer.WriteString("manual"u8, parameterValueSet.Manual.ToJsonString()); + writer.WriteString("published"u8, parameterValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.1.0"); + writer.WritePropertyName("actualOption"u8); + + if(parameterValueSet.ActualOption.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(parameterValueSet.ActualState.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterValueSet.Iid); + writer.WriteString("manual"u8, parameterValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteString("published"u8, parameterValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.2.0"); + writer.WritePropertyName("actualOption"u8); + + if(parameterValueSet.ActualOption.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(parameterValueSet.ActualState.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterValueSet.Iid); + writer.WriteString("manual"u8, parameterValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteString("published"u8, parameterValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterValueSet.Actor.HasValue) + { + writer.WriteStringValue(parameterValueSet.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualOption"u8); + + if(parameterValueSet.ActualOption.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualOption.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(parameterValueSet.ActualState.HasValue) + { + writer.WriteStringValue(parameterValueSet.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterValueSet.Iid); + writer.WriteString("manual"u8, parameterValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteString("published"u8, parameterValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterValueSet); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs index 319c10ea9..b300a61d0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParameterizedCategoryRule = CDP4Common.DTO.ParameterizedCategoryRule; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class ParameterizedCategoryRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JValue(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "parameterType", parameterType => new JArray(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParameterizedCategoryRule parameterizedCategoryRule) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](parameterizedCategoryRule.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](parameterizedCategoryRule.Category)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parameterizedCategoryRule.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](parameterizedCategoryRule.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parameterizedCategoryRule.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](parameterizedCategoryRule.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parameterizedCategoryRule.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](parameterizedCategoryRule.Name)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parameterizedCategoryRule.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](parameterizedCategoryRule.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parameterizedCategoryRule.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("category"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterType"u8); + + if(value is IEnumerable objectListParameterType) + { + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterizedCategoryRule"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParameterizedCategoryRule parameterizedCategoryRule) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParameterizedCategoryRule", nameof(thing)); } - var parameterizedCategoryRule = thing as ParameterizedCategoryRule; - if (parameterizedCategoryRule == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterizedCategoryRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParameterizedCategoryRule."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterizedCategoryRule.Actor.HasValue) + { + writer.WriteStringValue(parameterizedCategoryRule.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parameterizedCategoryRule); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs index a7b92c322..767379e48 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParametricConstraint = CDP4Common.DTO.ParametricConstraint; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,486 @@ namespace CDP4JsonSerializer public class ParametricConstraintSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "expression", expression => new JArray(expression) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "topExpression", topExpression => new JValue(topExpression) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParametricConstraint parametricConstraint) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), parametricConstraint.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](parametricConstraint.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](parametricConstraint.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("expression", this.PropertySerializerMap["expression"](parametricConstraint.Expression.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](parametricConstraint.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](parametricConstraint.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](parametricConstraint.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](parametricConstraint.ThingPreference)); - jsonObject.Add("topExpression", this.PropertySerializerMap["topExpression"](parametricConstraint.TopExpression)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "expression": + var allowedVersionsForExpression = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExpression.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("expression"u8); + + if(value is IEnumerable objectListExpression) + { + foreach(var expressionItem in objectListExpression.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "topexpression": + var allowedVersionsForTopExpression = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTopExpression.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("topExpression"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParametricConstraint"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParametricConstraint parametricConstraint) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParametricConstraint", nameof(thing)); } - var parametricConstraint = thing as ParametricConstraint; - if (parametricConstraint == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ParametricConstraint."); + Logger.Log(LogLevel.Info, "Skipping serialization of ParametricConstraint since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); + writer.WriteStartArray("expression"u8); + + foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parametricConstraint.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parametricConstraint.RevisionNumber); + writer.WritePropertyName("topExpression"u8); + + if(parametricConstraint.TopExpression.HasValue) + { + writer.WriteStringValue(parametricConstraint.TopExpression.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parametricConstraint.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); + + foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parametricConstraint.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parametricConstraint.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parametricConstraint.RevisionNumber); + writer.WritePropertyName("topExpression"u8); + + if(parametricConstraint.TopExpression.HasValue) + { + writer.WriteStringValue(parametricConstraint.TopExpression.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parametricConstraint.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); + + foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parametricConstraint.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parametricConstraint.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parametricConstraint.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parametricConstraint.ThingPreference); + writer.WritePropertyName("topExpression"u8); + + if(parametricConstraint.TopExpression.HasValue) + { + writer.WriteStringValue(parametricConstraint.TopExpression.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parametricConstraint.Actor.HasValue) + { + writer.WriteStringValue(parametricConstraint.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parametricConstraint.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); + + foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parametricConstraint.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parametricConstraint.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parametricConstraint.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parametricConstraint.ThingPreference); + writer.WritePropertyName("topExpression"u8); + + if(parametricConstraint.TopExpression.HasValue) + { + writer.WriteStringValue(parametricConstraint.TopExpression.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(parametricConstraint); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs index 0ce446fdb..d3241fb99 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParticipantPermission = CDP4Common.DTO.ParticipantPermission; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class ParticipantPermissionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "accessRight", accessRight => new JValue(accessRight.ToString()) }, - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "objectClass", objectClass => new JValue(objectClass.ToString()) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParticipantPermission participantPermission) - { - var jsonObject = new JObject(); - jsonObject.Add("accessRight", this.PropertySerializerMap["accessRight"](Enum.GetName(typeof(CDP4Common.CommonData.ParticipantAccessRightKind), participantPermission.AccessRight))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), participantPermission.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](participantPermission.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](participantPermission.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](participantPermission.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](participantPermission.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](participantPermission.ModifiedOn)); - jsonObject.Add("objectClass", this.PropertySerializerMap["objectClass"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), participantPermission.ObjectClass))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](participantPermission.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](participantPermission.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "accessright": + var allowedVersionsForAccessRight = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForAccessRight.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("accessRight"u8); + + if(value != null) + { + writer.WriteStringValue(((ParticipantAccessRightKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; + + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "objectclass": + var allowedVersionsForObjectClass = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForObjectClass.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("objectClass"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParticipantPermission"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParticipantPermission participantPermission) + { + throw new ArgumentException("The thing shall be a ParticipantPermission", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantPermission since Version is below 1.0.0"); + return; } - var participantPermission = thing as ParticipantPermission; - if (participantPermission == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ParticipantPermission."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.0.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.1.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.2.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantPermission.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.3.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("actor"u8); + + if(participantPermission.Actor.HasValue) + { + writer.WriteStringValue(participantPermission.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantPermission.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(participantPermission); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs index e55db07f1..8d97e9a73 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ParticipantRole = CDP4Common.DTO.ParticipantRole; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class ParticipantRoleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "participantPermission", participantPermission => new JArray(participantPermission) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ParticipantRole participantRole) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](participantRole.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), participantRole.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](participantRole.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](participantRole.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](participantRole.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](participantRole.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](participantRole.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](participantRole.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](participantRole.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](participantRole.Name)); - jsonObject.Add("participantPermission", this.PropertySerializerMap["participantPermission"](participantRole.ParticipantPermission.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](participantRole.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](participantRole.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](participantRole.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "participantpermission": + var allowedVersionsForParticipantPermission = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParticipantPermission.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("participantPermission"u8); + + if(value is IEnumerable objectListParticipantPermission) + { + foreach(var participantPermissionItem in objectListParticipantPermission.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParticipantRole"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ParticipantRole participantRole) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ParticipantRole", nameof(thing)); } - var participantRole = thing as ParticipantRole; - if (participantRole == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a ParticipantRole."); + Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantRole since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); + + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); + + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); + + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantRole.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(participantRole.Actor.HasValue) + { + writer.WriteStringValue(participantRole.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); + + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantRole.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(participantRole); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs index f00f210c1..e178a731d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Participant = CDP4Common.DTO.Participant; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,552 @@ namespace CDP4JsonSerializer public class ParticipantSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "domain", domain => new JArray(domain) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isActive", isActive => new JValue(isActive) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "person", person => new JValue(person) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "role", role => new JValue(role) }, - { "selectedDomain", selectedDomain => new JValue(selectedDomain) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Participant participant) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), participant.ClassKind))); - jsonObject.Add("domain", this.PropertySerializerMap["domain"](participant.Domain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](participant.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](participant.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](participant.Iid)); - jsonObject.Add("isActive", this.PropertySerializerMap["isActive"](participant.IsActive)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](participant.ModifiedOn)); - jsonObject.Add("person", this.PropertySerializerMap["person"](participant.Person)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](participant.RevisionNumber)); - jsonObject.Add("role", this.PropertySerializerMap["role"](participant.Role)); - jsonObject.Add("selectedDomain", this.PropertySerializerMap["selectedDomain"](participant.SelectedDomain)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](participant.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "domain": + var allowedVersionsForDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domain"u8); + + if(value is IEnumerable objectListDomain) + { + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isactive": + var allowedVersionsForIsActive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsActive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isActive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "person": + var allowedVersionsForPerson = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPerson.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("person"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "role": + var allowedVersionsForRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRole.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("role"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "selecteddomain": + var allowedVersionsForSelectedDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSelectedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("selectedDomain"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Participant"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Participant participant) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Participant", nameof(thing)); } - var participant = thing as Participant; - if (participant == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Participant since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Participant."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participant.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(participant.Actor.HasValue) + { + writer.WriteStringValue(participant.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participant.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(participant); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs index 6eb3d7494..d253e3ace 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using PersonPermission = CDP4Common.DTO.PersonPermission; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,460 @@ namespace CDP4JsonSerializer public class PersonPermissionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "accessRight", accessRight => new JValue(accessRight.ToString()) }, - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "objectClass", objectClass => new JValue(objectClass.ToString()) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(PersonPermission personPermission) - { - var jsonObject = new JObject(); - jsonObject.Add("accessRight", this.PropertySerializerMap["accessRight"](Enum.GetName(typeof(CDP4Common.CommonData.PersonAccessRightKind), personPermission.AccessRight))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), personPermission.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](personPermission.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](personPermission.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](personPermission.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](personPermission.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](personPermission.ModifiedOn)); - jsonObject.Add("objectClass", this.PropertySerializerMap["objectClass"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), personPermission.ObjectClass))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](personPermission.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](personPermission.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "accessright": + var allowedVersionsForAccessRight = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForAccessRight.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("accessRight"u8); + + if(value != null) + { + writer.WriteStringValue(((PersonAccessRightKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; + + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "objectclass": + var allowedVersionsForObjectClass = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForObjectClass.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("objectClass"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PersonPermission"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not PersonPermission personPermission) + { + throw new ArgumentException("The thing shall be a PersonPermission", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of PersonPermission since Version is below 1.0.0"); + return; } - var personPermission = thing as PersonPermission; - if (personPermission == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a PersonPermission."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.0.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.1.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.2.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personPermission.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.3.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("actor"u8); + + if(personPermission.Actor.HasValue) + { + writer.WriteStringValue(personPermission.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personPermission.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(personPermission); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs index dd4e35b4b..6fecd76eb 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using PersonRole = CDP4Common.DTO.PersonRole; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class PersonRoleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "personPermission", personPermission => new JArray(personPermission) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(PersonRole personRole) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](personRole.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), personRole.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](personRole.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](personRole.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](personRole.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](personRole.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](personRole.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](personRole.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](personRole.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](personRole.Name)); - jsonObject.Add("personPermission", this.PropertySerializerMap["personPermission"](personRole.PersonPermission.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](personRole.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](personRole.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](personRole.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "personpermission": + var allowedVersionsForPersonPermission = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPersonPermission.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("personPermission"u8); + + if(value is IEnumerable objectListPersonPermission) + { + foreach(var personPermissionItem in objectListPersonPermission.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PersonRole"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not PersonRole personRole) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a PersonRole", nameof(thing)); } - var personRole = thing as PersonRole; - if (personRole == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a PersonRole."); + Logger.Log(LogLevel.Info, "Skipping serialization of PersonRole since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); + + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); + + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); + + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personRole.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(personRole.Actor.HasValue) + { + writer.WriteStringValue(personRole.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); + + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personRole.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(personRole); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs index 477319e50..632571c77 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Person = CDP4Common.DTO.Person; /// /// The purpose of the class is to provide a specific serializer @@ -44,95 +50,1120 @@ namespace CDP4JsonSerializer public class PersonSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultDomain", defaultDomain => new JValue(defaultDomain) }, - { "defaultEmailAddress", defaultEmailAddress => new JValue(defaultEmailAddress) }, - { "defaultTelephoneNumber", defaultTelephoneNumber => new JValue(defaultTelephoneNumber) }, - { "emailAddress", emailAddress => new JArray(emailAddress) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "givenName", givenName => new JValue(givenName) }, - { "iid", iid => new JValue(iid) }, - { "isActive", isActive => new JValue(isActive) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "organization", organization => new JValue(organization) }, - { "organizationalUnit", organizationalUnit => new JValue(organizationalUnit) }, - { "password", password => new JValue(password) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "role", role => new JValue(role) }, - { "shortName", shortName => new JValue(shortName) }, - { "surname", surname => new JValue(surname) }, - { "telephoneNumber", telephoneNumber => new JArray(telephoneNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "userPreference", userPreference => new JArray(userPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Person person) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), person.ClassKind))); - jsonObject.Add("defaultDomain", this.PropertySerializerMap["defaultDomain"](person.DefaultDomain)); - jsonObject.Add("defaultEmailAddress", this.PropertySerializerMap["defaultEmailAddress"](person.DefaultEmailAddress)); - jsonObject.Add("defaultTelephoneNumber", this.PropertySerializerMap["defaultTelephoneNumber"](person.DefaultTelephoneNumber)); - jsonObject.Add("emailAddress", this.PropertySerializerMap["emailAddress"](person.EmailAddress.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](person.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](person.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("givenName", this.PropertySerializerMap["givenName"](person.GivenName)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](person.Iid)); - jsonObject.Add("isActive", this.PropertySerializerMap["isActive"](person.IsActive)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](person.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](person.ModifiedOn)); - jsonObject.Add("organization", this.PropertySerializerMap["organization"](person.Organization)); - jsonObject.Add("organizationalUnit", this.PropertySerializerMap["organizationalUnit"](person.OrganizationalUnit)); - jsonObject.Add("password", this.PropertySerializerMap["password"](person.Password)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](person.RevisionNumber)); - jsonObject.Add("role", this.PropertySerializerMap["role"](person.Role)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](person.ShortName)); - jsonObject.Add("surname", this.PropertySerializerMap["surname"](person.Surname)); - jsonObject.Add("telephoneNumber", this.PropertySerializerMap["telephoneNumber"](person.TelephoneNumber.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](person.ThingPreference)); - jsonObject.Add("userPreference", this.PropertySerializerMap["userPreference"](person.UserPreference.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultdomain": + var allowedVersionsForDefaultDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultDomain.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultDomain"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultemailaddress": + var allowedVersionsForDefaultEmailAddress = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultEmailAddress.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultEmailAddress"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaulttelephonenumber": + var allowedVersionsForDefaultTelephoneNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultTelephoneNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "emailaddress": + var allowedVersionsForEmailAddress = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForEmailAddress.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("emailAddress"u8); + + if(value is IEnumerable objectListEmailAddress) + { + foreach(var emailAddressItem in objectListEmailAddress.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "givenname": + var allowedVersionsForGivenName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGivenName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("givenName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isactive": + var allowedVersionsForIsActive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsActive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isActive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "organization": + var allowedVersionsForOrganization = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganization.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("organization"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "organizationalunit": + var allowedVersionsForOrganizationalUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganizationalUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("organizationalUnit"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "password": + var allowedVersionsForPassword = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPassword.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("password"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "role": + var allowedVersionsForRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRole.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("role"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "surname": + var allowedVersionsForSurname = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSurname.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("surname"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "telephonenumber": + var allowedVersionsForTelephoneNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTelephoneNumber.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("telephoneNumber"u8); + + if(value is IEnumerable objectListTelephoneNumber) + { + foreach(var telephoneNumberItem in objectListTelephoneNumber.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "userpreference": + var allowedVersionsForUserPreference = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUserPreference.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("userPreference"u8); + + if(value is IEnumerable objectListUserPreference) + { + foreach(var userPreferenceItem in objectListUserPreference.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Person"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Person person) + { + throw new ArgumentException("The thing shall be a Person", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Person since Version is below 1.0.0"); + return; } - var person = thing as Person; - if (person == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Person."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(person.ClassKind.ToString()); + writer.WritePropertyName("defaultDomain"u8); + + if(person.DefaultDomain.HasValue) + { + writer.WriteStringValue(person.DefaultDomain.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultEmailAddress"u8); + + if(person.DefaultEmailAddress.HasValue) + { + writer.WriteStringValue(person.DefaultEmailAddress.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(person.DefaultTelephoneNumber.HasValue) + { + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("emailAddress"u8); + + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); + writer.WriteStringValue(person.GivenName); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(person.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(person.IsActive); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("organization"u8); + + if(person.Organization.HasValue) + { + writer.WriteStringValue(person.Organization.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); + + if(person.Role.HasValue) + { + writer.WriteStringValue(person.Role.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); + + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("userPreference"u8); + + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(person.ClassKind.ToString()); + writer.WritePropertyName("defaultDomain"u8); + + if(person.DefaultDomain.HasValue) + { + writer.WriteStringValue(person.DefaultDomain.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultEmailAddress"u8); + + if(person.DefaultEmailAddress.HasValue) + { + writer.WriteStringValue(person.DefaultEmailAddress.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(person.DefaultTelephoneNumber.HasValue) + { + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("emailAddress"u8); + + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); + writer.WriteStringValue(person.GivenName); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(person.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(person.IsActive); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + + if(person.Organization.HasValue) + { + writer.WriteStringValue(person.Organization.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); + + if(person.Role.HasValue) + { + writer.WriteStringValue(person.Role.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); + + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("userPreference"u8); + + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(person.ClassKind.ToString()); + writer.WritePropertyName("defaultDomain"u8); + + if(person.DefaultDomain.HasValue) + { + writer.WriteStringValue(person.DefaultDomain.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultEmailAddress"u8); + + if(person.DefaultEmailAddress.HasValue) + { + writer.WriteStringValue(person.DefaultEmailAddress.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(person.DefaultTelephoneNumber.HasValue) + { + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("emailAddress"u8); + + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); + writer.WriteStringValue(person.GivenName); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(person.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(person.IsActive); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + + if(person.Organization.HasValue) + { + writer.WriteStringValue(person.Organization.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); + + if(person.Role.HasValue) + { + writer.WriteStringValue(person.Role.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); + + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(person.ThingPreference); + writer.WriteStartArray("userPreference"u8); + + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(person.Actor.HasValue) + { + writer.WriteStringValue(person.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(person.ClassKind.ToString()); + writer.WritePropertyName("defaultDomain"u8); + + if(person.DefaultDomain.HasValue) + { + writer.WriteStringValue(person.DefaultDomain.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultEmailAddress"u8); + + if(person.DefaultEmailAddress.HasValue) + { + writer.WriteStringValue(person.DefaultEmailAddress.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(person.DefaultTelephoneNumber.HasValue) + { + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("emailAddress"u8); + + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); + writer.WriteStringValue(person.GivenName); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(person.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(person.IsActive); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + + if(person.Organization.HasValue) + { + writer.WriteStringValue(person.Organization.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); + + if(person.Role.HasValue) + { + writer.WriteStringValue(person.Role.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); + + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(person.ThingPreference); + writer.WriteStartArray("userPreference"u8); + + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(person); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs index ee87b03ea..971c3903f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Point = CDP4Common.DTO.Point; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,439 @@ namespace CDP4JsonSerializer public class PointSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "x", x => new JValue(x) }, - { "y", y => new JValue(y) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Point point) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), point.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](point.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](point.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](point.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](point.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](point.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](point.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](point.ThingPreference)); - jsonObject.Add("x", this.PropertySerializerMap["x"](point.X)); - jsonObject.Add("y", this.PropertySerializerMap["y"](point.Y)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "x": + var allowedVersionsForX = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForX.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("x"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "y": + var allowedVersionsForY = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForY.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("y"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Point"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Point point) + { + throw new ArgumentException("The thing shall be a Point", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Point since Version is below 1.1.0"); + return; } - var point = thing as Point; - if (point == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Point."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(point.ThingPreference); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(point.Actor.HasValue) + { + writer.WriteStringValue(point.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(point.ThingPreference); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(point); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs index fefa85fcd..0d1cd3b88 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using PossibleFiniteStateList = CDP4Common.DTO.PossibleFiniteStateList; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,820 @@ namespace CDP4JsonSerializer public class PossibleFiniteStateListSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultState", defaultState => new JValue(defaultState) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "possibleState", possibleState => new JArray(((IEnumerable)possibleState).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(PossibleFiniteStateList possibleFiniteStateList) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](possibleFiniteStateList.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](possibleFiniteStateList.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), possibleFiniteStateList.ClassKind))); - jsonObject.Add("defaultState", this.PropertySerializerMap["defaultState"](possibleFiniteStateList.DefaultState)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](possibleFiniteStateList.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](possibleFiniteStateList.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](possibleFiniteStateList.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](possibleFiniteStateList.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](possibleFiniteStateList.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](possibleFiniteStateList.Owner)); - jsonObject.Add("possibleState", this.PropertySerializerMap["possibleState"](possibleFiniteStateList.PossibleState.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](possibleFiniteStateList.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](possibleFiniteStateList.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](possibleFiniteStateList.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultstate": + var allowedVersionsForDefaultState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultState.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultState"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblestate": + var allowedVersionsForPossibleState = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleState.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleState"u8); + + if(value is IEnumerable objectListPossibleState) + { + foreach(var possibleStateItem in objectListPossibleState.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteStateList"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not PossibleFiniteStateList possibleFiniteStateList) + { + throw new ArgumentException("The thing shall be a PossibleFiniteStateList", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of PossibleFiniteStateList since Version is below 1.0.0"); + return; } - var possibleFiniteStateList = thing as PossibleFiniteStateList; - if (possibleFiniteStateList == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a PossibleFiniteStateList."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteStateList.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(possibleFiniteStateList.Actor.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteStateList.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(possibleFiniteStateList); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs index 232282589..8829ee1bb 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using PossibleFiniteState = CDP4Common.DTO.PossibleFiniteState; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,600 @@ namespace CDP4JsonSerializer public class PossibleFiniteStateSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(PossibleFiniteState possibleFiniteState) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](possibleFiniteState.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), possibleFiniteState.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](possibleFiniteState.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](possibleFiniteState.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](possibleFiniteState.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](possibleFiniteState.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](possibleFiniteState.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](possibleFiniteState.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](possibleFiniteState.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](possibleFiniteState.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteState"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not PossibleFiniteState possibleFiniteState) + { + throw new ArgumentException("The thing shall be a PossibleFiniteState", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of PossibleFiniteState since Version is below 1.0.0"); + return; } - var possibleFiniteState = thing as PossibleFiniteState; - if (possibleFiniteState == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a PossibleFiniteState."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteState.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteState.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteState.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteState.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteState.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteState.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteState.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteState.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteState.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteState.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteState.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteState.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteState.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteState.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteState.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteState.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(possibleFiniteState.Actor.HasValue) + { + writer.WriteStringValue(possibleFiniteState.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in possibleFiniteState.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteState.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteState.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteState.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteState.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteState.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(possibleFiniteState); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs index d1f86fc85..f6ed496f1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using PrefixedUnit = CDP4Common.DTO.PrefixedUnit; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,634 @@ namespace CDP4JsonSerializer public class PrefixedUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "prefix", prefix => new JValue(prefix) }, - { "referenceUnit", referenceUnit => new JValue(referenceUnit) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(PrefixedUnit prefixedUnit) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](prefixedUnit.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), prefixedUnit.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](prefixedUnit.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](prefixedUnit.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](prefixedUnit.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](prefixedUnit.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](prefixedUnit.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](prefixedUnit.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](prefixedUnit.ModifiedOn)); - jsonObject.Add("prefix", this.PropertySerializerMap["prefix"](prefixedUnit.Prefix)); - jsonObject.Add("referenceUnit", this.PropertySerializerMap["referenceUnit"](prefixedUnit.ReferenceUnit)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](prefixedUnit.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](prefixedUnit.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "prefix": + var allowedVersionsForPrefix = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrefix.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("prefix"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referenceunit": + var allowedVersionsForReferenceUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referenceUnit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PrefixedUnit"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not PrefixedUnit prefixedUnit) + { + throw new ArgumentException("The thing shall be a PrefixedUnit", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of PrefixedUnit since Version is below 1.0.0"); + return; } - var prefixedUnit = thing as PrefixedUnit; - if (prefixedUnit == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a PrefixedUnit."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(prefixedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + writer.WritePropertyName("prefix"u8); + writer.WriteStringValue(prefixedUnit.Prefix); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(prefixedUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(prefixedUnit.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(prefixedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(prefixedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("prefix"u8); + writer.WriteStringValue(prefixedUnit.Prefix); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(prefixedUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(prefixedUnit.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(prefixedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(prefixedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("prefix"u8); + writer.WriteStringValue(prefixedUnit.Prefix); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(prefixedUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(prefixedUnit.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(prefixedUnit.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(prefixedUnit.Actor.HasValue) + { + writer.WriteStringValue(prefixedUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(prefixedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(prefixedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("prefix"u8); + writer.WriteStringValue(prefixedUnit.Prefix); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(prefixedUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(prefixedUnit.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(prefixedUnit.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(prefixedUnit); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs index 6c60f9637..69e006cea 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Publication = CDP4Common.DTO.Publication; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,508 @@ namespace CDP4JsonSerializer public class PublicationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "domain", domain => new JArray(domain) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "publishedParameter", publishedParameter => new JArray(publishedParameter) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Publication publication) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), publication.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](publication.CreatedOn)); - jsonObject.Add("domain", this.PropertySerializerMap["domain"](publication.Domain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](publication.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](publication.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](publication.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](publication.ModifiedOn)); - jsonObject.Add("publishedParameter", this.PropertySerializerMap["publishedParameter"](publication.PublishedParameter.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](publication.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](publication.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "domain": + var allowedVersionsForDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domain"u8); + + if(value is IEnumerable objectListDomain) + { + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "publishedparameter": + var allowedVersionsForPublishedParameter = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublishedParameter.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("publishedParameter"u8); + + if(value is IEnumerable objectListPublishedParameter) + { + foreach(var publishedParameterItem in objectListPublishedParameter.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Publication"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Publication publication) + { + throw new ArgumentException("The thing shall be a Publication", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Publication since Version is below 1.0.0"); + return; } - var publication = thing as Publication; - if (publication == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Publication."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(publication.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(publication.Actor.HasValue) + { + writer.WriteStringValue(publication.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(publication.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(publication); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs index cf157155e..0519f1a24 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using QuantityKindFactor = CDP4Common.DTO.QuantityKindFactor; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class QuantityKindFactorSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "exponent", exponent => new JValue(exponent) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "quantityKind", quantityKind => new JValue(quantityKind) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(QuantityKindFactor quantityKindFactor) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), quantityKindFactor.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("exponent", this.PropertySerializerMap["exponent"](quantityKindFactor.Exponent)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](quantityKindFactor.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](quantityKindFactor.ModifiedOn)); - jsonObject.Add("quantityKind", this.PropertySerializerMap["quantityKind"](quantityKindFactor.QuantityKind)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](quantityKindFactor.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](quantityKindFactor.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "exponent": + var allowedVersionsForExponent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExponent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("exponent"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "quantitykind": + var allowedVersionsForQuantityKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForQuantityKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("quantityKind"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the QuantityKindFactor"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not QuantityKindFactor quantityKindFactor) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a QuantityKindFactor", nameof(thing)); } - var quantityKindFactor = thing as QuantityKindFactor; - if (quantityKindFactor == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of QuantityKindFactor since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a QuantityKindFactor."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(quantityKindFactor.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(quantityKindFactor.Actor.HasValue) + { + writer.WriteStringValue(quantityKindFactor.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(quantityKindFactor.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(quantityKindFactor); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs index 794779e10..4ad6a83b7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RatioScale = CDP4Common.DTO.RatioScale; /// /// The purpose of the class is to provide a specific serializer @@ -44,97 +50,1022 @@ namespace CDP4JsonSerializer public class RatioScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "isMaximumInclusive", isMaximumInclusive => new JValue(isMaximumInclusive) }, - { "isMinimumInclusive", isMinimumInclusive => new JValue(isMinimumInclusive) }, - { "mappingToReferenceScale", mappingToReferenceScale => new JArray(mappingToReferenceScale) }, - { "maximumPermissibleValue", maximumPermissibleValue => new JValue(maximumPermissibleValue) }, - { "minimumPermissibleValue", minimumPermissibleValue => new JValue(minimumPermissibleValue) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "negativeValueConnotation", negativeValueConnotation => new JValue(negativeValueConnotation) }, - { "numberSet", numberSet => new JValue(numberSet.ToString()) }, - { "positiveValueConnotation", positiveValueConnotation => new JValue(positiveValueConnotation) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - { "valueDefinition", valueDefinition => new JArray(valueDefinition) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RatioScale ratioScale) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](ratioScale.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), ratioScale.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](ratioScale.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](ratioScale.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](ratioScale.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](ratioScale.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](ratioScale.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](ratioScale.IsDeprecated)); - jsonObject.Add("isMaximumInclusive", this.PropertySerializerMap["isMaximumInclusive"](ratioScale.IsMaximumInclusive)); - jsonObject.Add("isMinimumInclusive", this.PropertySerializerMap["isMinimumInclusive"](ratioScale.IsMinimumInclusive)); - jsonObject.Add("mappingToReferenceScale", this.PropertySerializerMap["mappingToReferenceScale"](ratioScale.MappingToReferenceScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("maximumPermissibleValue", this.PropertySerializerMap["maximumPermissibleValue"](ratioScale.MaximumPermissibleValue)); - jsonObject.Add("minimumPermissibleValue", this.PropertySerializerMap["minimumPermissibleValue"](ratioScale.MinimumPermissibleValue)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](ratioScale.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](ratioScale.Name)); - jsonObject.Add("negativeValueConnotation", this.PropertySerializerMap["negativeValueConnotation"](ratioScale.NegativeValueConnotation)); - jsonObject.Add("numberSet", this.PropertySerializerMap["numberSet"](Enum.GetName(typeof(CDP4Common.SiteDirectoryData.NumberSetKind), ratioScale.NumberSet))); - jsonObject.Add("positiveValueConnotation", this.PropertySerializerMap["positiveValueConnotation"](ratioScale.PositiveValueConnotation)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](ratioScale.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](ratioScale.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](ratioScale.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](ratioScale.Unit)); - jsonObject.Add("valueDefinition", this.PropertySerializerMap["valueDefinition"](ratioScale.ValueDefinition.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + var allowedVersionsForIsMaximumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + var allowedVersionsForIsMinimumInclusive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + var allowedVersionsForMappingToReferenceScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + var allowedVersionsForMaximumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minimumpermissiblevalue": + var allowedVersionsForMinimumPermissibleValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + var allowedVersionsForNegativeValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + var allowedVersionsForNumberSet = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + var allowedVersionsForPositiveValueConnotation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuedefinition": + var allowedVersionsForValueDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueDefinition"u8); + + if(value is IEnumerable objectListValueDefinition) + { + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RatioScale"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RatioScale ratioScale) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a RatioScale", nameof(thing)); } - var ratioScale = thing as RatioScale; - if (ratioScale == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a RatioScale."); + Logger.Log(LogLevel.Info, "Skipping serialization of RatioScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ratioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ratioScale.Actor.HasValue) + { + writer.WriteStringValue(ratioScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ratioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(ratioScale); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs index 5fc66c14f..d86691242 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ReferenceSource = CDP4Common.DTO.ReferenceSource; /// /// The purpose of the class is to provide a specific serializer @@ -44,93 +50,1074 @@ namespace CDP4JsonSerializer public class ReferenceSourceSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "language", language => new JValue(language) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "publicationYear", publicationYear => new JValue(publicationYear) }, - { "publishedIn", publishedIn => new JValue(publishedIn) }, - { "publisher", publisher => new JValue(publisher) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "versionDate", versionDate => new JValue(versionDate != null ? ((DateTime)versionDate).ToString("yyyy-MM-ddTHH:mm:ss.fffZ") : null) }, - { "versionIdentifier", versionIdentifier => new JValue(versionIdentifier) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ReferenceSource referenceSource) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](referenceSource.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](referenceSource.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](referenceSource.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), referenceSource.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](referenceSource.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](referenceSource.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](referenceSource.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](referenceSource.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](referenceSource.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](referenceSource.IsDeprecated)); - jsonObject.Add("language", this.PropertySerializerMap["language"](referenceSource.Language)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](referenceSource.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](referenceSource.Name)); - jsonObject.Add("publicationYear", this.PropertySerializerMap["publicationYear"](referenceSource.PublicationYear)); - jsonObject.Add("publishedIn", this.PropertySerializerMap["publishedIn"](referenceSource.PublishedIn)); - jsonObject.Add("publisher", this.PropertySerializerMap["publisher"](referenceSource.Publisher)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](referenceSource.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](referenceSource.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](referenceSource.ThingPreference)); - jsonObject.Add("versionDate", this.PropertySerializerMap["versionDate"](referenceSource.VersionDate)); - jsonObject.Add("versionIdentifier", this.PropertySerializerMap["versionIdentifier"](referenceSource.VersionIdentifier)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "language": + var allowedVersionsForLanguage = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguage.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("language"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "publicationyear": + var allowedVersionsForPublicationYear = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublicationYear.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("publicationYear"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "publishedin": + var allowedVersionsForPublishedIn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublishedIn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("publishedIn"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "publisher": + var allowedVersionsForPublisher = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPublisher.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("publisher"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "versiondate": + var allowedVersionsForVersionDate = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForVersionDate.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("versionDate"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "versionidentifier": + var allowedVersionsForVersionIdentifier = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForVersionIdentifier.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("versionIdentifier"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ReferenceSource"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ReferenceSource referenceSource) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ReferenceSource", nameof(thing)); } - var referenceSource = thing as ReferenceSource; - if (referenceSource == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ReferenceSource since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ReferenceSource."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) + { + writer.WriteNumberValue(referenceSource.PublicationYear.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publishedIn"u8); + + if(referenceSource.PublishedIn.HasValue) + { + writer.WriteStringValue(referenceSource.PublishedIn.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publisher"u8); + + if(referenceSource.Publisher.HasValue) + { + writer.WriteStringValue(referenceSource.Publisher.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("versionDate"u8); + + if(referenceSource.VersionDate.HasValue) + { + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) + { + writer.WriteNumberValue(referenceSource.PublicationYear.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publishedIn"u8); + + if(referenceSource.PublishedIn.HasValue) + { + writer.WriteStringValue(referenceSource.PublishedIn.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publisher"u8); + + if(referenceSource.Publisher.HasValue) + { + writer.WriteStringValue(referenceSource.Publisher.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("versionDate"u8); + + if(referenceSource.VersionDate.HasValue) + { + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) + { + writer.WriteNumberValue(referenceSource.PublicationYear.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publishedIn"u8); + + if(referenceSource.PublishedIn.HasValue) + { + writer.WriteStringValue(referenceSource.PublishedIn.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publisher"u8); + + if(referenceSource.Publisher.HasValue) + { + writer.WriteStringValue(referenceSource.Publisher.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referenceSource.ThingPreference); + writer.WritePropertyName("versionDate"u8); + + if(referenceSource.VersionDate.HasValue) + { + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(referenceSource.Actor.HasValue) + { + writer.WriteStringValue(referenceSource.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) + { + writer.WriteNumberValue(referenceSource.PublicationYear.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publishedIn"u8); + + if(referenceSource.PublishedIn.HasValue) + { + writer.WriteStringValue(referenceSource.PublishedIn.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("publisher"u8); + + if(referenceSource.Publisher.HasValue) + { + writer.WriteStringValue(referenceSource.Publisher.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referenceSource.ThingPreference); + writer.WritePropertyName("versionDate"u8); + + if(referenceSource.VersionDate.HasValue) + { + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(referenceSource); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs index 5003f32fe..48553ff25 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ReferencerRule = CDP4Common.DTO.ReferencerRule; /// /// The purpose of the class is to provide a specific serializer @@ -44,85 +50,794 @@ namespace CDP4JsonSerializer public class ReferencerRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "maxReferenced", maxReferenced => new JValue(maxReferenced) }, - { "minReferenced", minReferenced => new JValue(minReferenced) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "referencedCategory", referencedCategory => new JArray(referencedCategory) }, - { "referencingCategory", referencingCategory => new JValue(referencingCategory) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ReferencerRule referencerRule) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](referencerRule.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), referencerRule.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](referencerRule.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](referencerRule.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](referencerRule.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](referencerRule.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](referencerRule.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](referencerRule.IsDeprecated)); - jsonObject.Add("maxReferenced", this.PropertySerializerMap["maxReferenced"](referencerRule.MaxReferenced)); - jsonObject.Add("minReferenced", this.PropertySerializerMap["minReferenced"](referencerRule.MinReferenced)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](referencerRule.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](referencerRule.Name)); - jsonObject.Add("referencedCategory", this.PropertySerializerMap["referencedCategory"](referencerRule.ReferencedCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("referencingCategory", this.PropertySerializerMap["referencingCategory"](referencerRule.ReferencingCategory)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](referencerRule.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](referencerRule.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](referencerRule.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "maxreferenced": + var allowedVersionsForMaxReferenced = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMaxReferenced.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maxReferenced"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "minreferenced": + var allowedVersionsForMinReferenced = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForMinReferenced.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minReferenced"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencedcategory": + var allowedVersionsForReferencedCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("referencedCategory"u8); + + if(value is IEnumerable objectListReferencedCategory) + { + foreach(var referencedCategoryItem in objectListReferencedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "referencingcategory": + var allowedVersionsForReferencingCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencingCategory.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referencingCategory"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ReferencerRule"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ReferencerRule referencerRule) + { + throw new ArgumentException("The thing shall be a ReferencerRule", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ReferencerRule since Version is below 1.0.0"); + return; } - var referencerRule = thing as ReferencerRule; - if (referencerRule == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ReferencerRule."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); + + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); + + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); + + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referencerRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(referencerRule.Actor.HasValue) + { + writer.WriteStringValue(referencerRule.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); + + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referencerRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(referencerRule); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs index d16185572..c7a9b5bf9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RelationalExpression = CDP4Common.DTO.RelationalExpression; /// /// The purpose of the class is to provide a specific serializer @@ -44,73 +50,516 @@ namespace CDP4JsonSerializer public class RelationalExpressionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "relationalOperator", relationalOperator => new JValue(relationalOperator.ToString()) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(((ValueArray)value).ToJsonString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RelationalExpression relationalExpression) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), relationalExpression.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](relationalExpression.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](relationalExpression.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](relationalExpression.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](relationalExpression.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](relationalExpression.ParameterType)); - jsonObject.Add("relationalOperator", this.PropertySerializerMap["relationalOperator"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.RelationalOperatorKind), relationalExpression.RelationalOperator))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](relationalExpression.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](relationalExpression.Scale)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](relationalExpression.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](relationalExpression.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relationaloperator": + var allowedVersionsForRelationalOperator = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelationalOperator.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("relationalOperator"u8); + + if(value != null) + { + writer.WriteStringValue(((RelationalOperatorKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RelationalExpression"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RelationalExpression relationalExpression) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a RelationalExpression", nameof(thing)); } - var relationalExpression = thing as RelationalExpression; - if (relationalExpression == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a RelationalExpression."); + Logger.Log(LogLevel.Info, "Skipping serialization of RelationalExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationalExpression.ThingPreference); + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(relationalExpression.Actor.HasValue) + { + writer.WriteStringValue(relationalExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationalExpression.ThingPreference); + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(relationalExpression); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs index 970207037..a7653761d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RelationshipParameterValue = CDP4Common.DTO.RelationshipParameterValue; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,453 @@ namespace CDP4JsonSerializer public class RelationshipParameterValueSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(((ValueArray)value).ToJsonString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RelationshipParameterValue relationshipParameterValue) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), relationshipParameterValue.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](relationshipParameterValue.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](relationshipParameterValue.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](relationshipParameterValue.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](relationshipParameterValue.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](relationshipParameterValue.Scale)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](relationshipParameterValue.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](relationshipParameterValue.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RelationshipParameterValue"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RelationshipParameterValue relationshipParameterValue) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a RelationshipParameterValue", nameof(thing)); } - var relationshipParameterValue = thing as RelationshipParameterValue; - if (relationshipParameterValue == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a RelationshipParameterValue."); + Logger.Log(LogLevel.Info, "Skipping serialization of RelationshipParameterValue since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationshipParameterValue.ThingPreference); + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(relationshipParameterValue.Actor.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationshipParameterValue.ThingPreference); + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(relationshipParameterValue); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs index 5126401cf..c9ae82ee9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RequestForDeviation = CDP4Common.DTO.RequestForDeviation; /// /// The purpose of the class is to provide a specific serializer @@ -44,95 +50,928 @@ namespace CDP4JsonSerializer public class RequestForDeviationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RequestForDeviation requestForDeviation) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](requestForDeviation.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](requestForDeviation.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](requestForDeviation.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), requestForDeviation.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requestForDeviation.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](requestForDeviation.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](requestForDeviation.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](requestForDeviation.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requestForDeviation.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requestForDeviation.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requestForDeviation.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](requestForDeviation.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requestForDeviation.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](requestForDeviation.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](requestForDeviation.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](requestForDeviation.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requestForDeviation.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](requestForDeviation.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](requestForDeviation.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), requestForDeviation.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requestForDeviation.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](requestForDeviation.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForDeviation"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RequestForDeviation requestForDeviation) + { + throw new ArgumentException("The thing shall be a RequestForDeviation", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of RequestForDeviation since Version is below 1.1.0"); + return; } - var requestForDeviation = thing as RequestForDeviation; - if (requestForDeviation == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a RequestForDeviation."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForDeviation.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requestForDeviation.Actor.HasValue) + { + writer.WriteStringValue(requestForDeviation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForDeviation.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requestForDeviation); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs index fab849eb3..322fed874 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RequestForWaiver = CDP4Common.DTO.RequestForWaiver; /// /// The purpose of the class is to provide a specific serializer @@ -44,95 +50,928 @@ namespace CDP4JsonSerializer public class RequestForWaiverSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RequestForWaiver requestForWaiver) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](requestForWaiver.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](requestForWaiver.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](requestForWaiver.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), requestForWaiver.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requestForWaiver.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](requestForWaiver.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](requestForWaiver.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](requestForWaiver.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requestForWaiver.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requestForWaiver.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requestForWaiver.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](requestForWaiver.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requestForWaiver.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](requestForWaiver.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](requestForWaiver.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](requestForWaiver.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requestForWaiver.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](requestForWaiver.ShortName)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](requestForWaiver.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), requestForWaiver.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requestForWaiver.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](requestForWaiver.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForWaiver"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RequestForWaiver requestForWaiver) + { + throw new ArgumentException("The thing shall be a RequestForWaiver", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of RequestForWaiver since Version is below 1.1.0"); + return; } - var requestForWaiver = thing as RequestForWaiver; - if (requestForWaiver == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a RequestForWaiver."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForWaiver.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requestForWaiver.Actor.HasValue) + { + writer.WriteStringValue(requestForWaiver.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForWaiver.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requestForWaiver); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs index 60b3a6930..489a7dab0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Requirement = CDP4Common.DTO.Requirement; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,912 @@ namespace CDP4JsonSerializer public class RequirementSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "group", group => new JValue(group) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterValue", parameterValue => new JArray(parameterValue) }, - { "parametricConstraint", parametricConstraint => new JArray(((IEnumerable)parametricConstraint).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Requirement requirement) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](requirement.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](requirement.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requirement.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](requirement.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requirement.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requirement.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("group", this.PropertySerializerMap["group"](requirement.Group)); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](requirement.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requirement.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](requirement.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requirement.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](requirement.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](requirement.Owner)); - jsonObject.Add("parameterValue", this.PropertySerializerMap["parameterValue"](requirement.ParameterValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("parametricConstraint", this.PropertySerializerMap["parametricConstraint"](requirement.ParametricConstraint.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requirement.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](requirement.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requirement.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "group": + var allowedVersionsForGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGroup.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("group"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalue": + var allowedVersionsForParameterValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + + writer.WriteEndArray(); + break; + case "parametricconstraint": + var allowedVersionsForParametricConstraint = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParametricConstraint.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parametricConstraint"u8); + + if(value is IEnumerable objectListParametricConstraint) + { + foreach(var parametricConstraintItem in objectListParametricConstraint.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Requirement"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Requirement requirement) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Requirement", nameof(thing)); } - var requirement = thing as Requirement; - if (requirement == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Requirement since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Requirement."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) + { + writer.WriteStringValue(requirement.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) + { + writer.WriteStringValue(requirement.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) + { + writer.WriteStringValue(requirement.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirement.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirement.Actor.HasValue) + { + writer.WriteStringValue(requirement.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) + { + writer.WriteStringValue(requirement.Group.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirement.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requirement); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs index 8d139c938..21e384c1f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RequirementsContainerParameterValue = CDP4Common.DTO.RequirementsContainerParameterValue; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,453 @@ namespace CDP4JsonSerializer public class RequirementsContainerParameterValueSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(((ValueArray)value).ToJsonString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RequirementsContainerParameterValue requirementsContainerParameterValue) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requirementsContainerParameterValue.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requirementsContainerParameterValue.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requirementsContainerParameterValue.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](requirementsContainerParameterValue.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requirementsContainerParameterValue.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](requirementsContainerParameterValue.Scale)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requirementsContainerParameterValue.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](requirementsContainerParameterValue.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsContainerParameterValue"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RequirementsContainerParameterValue requirementsContainerParameterValue) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a RequirementsContainerParameterValue", nameof(thing)); } - var requirementsContainerParameterValue = thing as RequirementsContainerParameterValue; - if (requirementsContainerParameterValue == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a RequirementsContainerParameterValue."); + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsContainerParameterValue since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirementsContainerParameterValue.Actor.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requirementsContainerParameterValue); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs index 3cd2879a4..496d84ec6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RequirementsGroup = CDP4Common.DTO.RequirementsGroup; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,790 @@ namespace CDP4JsonSerializer public class RequirementsGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "group", group => new JArray(group) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterValue", parameterValue => new JArray(parameterValue) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RequirementsGroup requirementsGroup) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](requirementsGroup.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](requirementsGroup.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requirementsGroup.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](requirementsGroup.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requirementsGroup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requirementsGroup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("group", this.PropertySerializerMap["group"](requirementsGroup.Group.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](requirementsGroup.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requirementsGroup.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requirementsGroup.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](requirementsGroup.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](requirementsGroup.Owner)); - jsonObject.Add("parameterValue", this.PropertySerializerMap["parameterValue"](requirementsGroup.ParameterValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requirementsGroup.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](requirementsGroup.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requirementsGroup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "group": + var allowedVersionsForGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("group"u8); + + if(value is IEnumerable objectListGroup) + { + foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalue": + var allowedVersionsForParameterValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsGroup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RequirementsGroup requirementsGroup) + { + throw new ArgumentException("The thing shall be a RequirementsGroup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsGroup since Version is below 1.0.0"); + return; } - var requirementsGroup = thing as RequirementsGroup; - if (requirementsGroup == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a RequirementsGroup."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirementsGroup.Actor.HasValue) + { + writer.WriteStringValue(requirementsGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requirementsGroup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs index f8022c191..3f9c5533f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RequirementsSpecification = CDP4Common.DTO.RequirementsSpecification; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,882 @@ namespace CDP4JsonSerializer public class RequirementsSpecificationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "group", group => new JArray(group) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "parameterValue", parameterValue => new JArray(parameterValue) }, - { "requirement", requirement => new JArray(requirement) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RequirementsSpecification requirementsSpecification) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](requirementsSpecification.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](requirementsSpecification.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), requirementsSpecification.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](requirementsSpecification.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("group", this.PropertySerializerMap["group"](requirementsSpecification.Group.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](requirementsSpecification.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](requirementsSpecification.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](requirementsSpecification.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](requirementsSpecification.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](requirementsSpecification.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](requirementsSpecification.Owner)); - jsonObject.Add("parameterValue", this.PropertySerializerMap["parameterValue"](requirementsSpecification.ParameterValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("requirement", this.PropertySerializerMap["requirement"](requirementsSpecification.Requirement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](requirementsSpecification.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](requirementsSpecification.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](requirementsSpecification.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "group": + var allowedVersionsForGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("group"u8); + + if(value is IEnumerable objectListGroup) + { + foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametervalue": + var allowedVersionsForParameterValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + + writer.WriteEndArray(); + break; + case "requirement": + var allowedVersionsForRequirement = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequirement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("requirement"u8); + + if(value is IEnumerable objectListRequirement) + { + foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsSpecification"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RequirementsSpecification requirementsSpecification) + { + throw new ArgumentException("The thing shall be a RequirementsSpecification", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsSpecification since Version is below 1.0.0"); + return; } - var requirementsSpecification = thing as RequirementsSpecification; - if (requirementsSpecification == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a RequirementsSpecification."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsSpecification.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirementsSpecification.Actor.HasValue) + { + writer.WriteStringValue(requirementsSpecification.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsSpecification.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(requirementsSpecification); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs index 761318705..ae3bf64b7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ReviewItemDiscrepancy = CDP4Common.DTO.ReviewItemDiscrepancy; /// /// The purpose of the class is to provide a specific serializer @@ -44,97 +50,977 @@ namespace CDP4JsonSerializer public class ReviewItemDiscrepancySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "approvedBy", approvedBy => new JArray(approvedBy) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classification", classification => new JValue(classification.ToString()) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "solution", solution => new JArray(solution) }, - { "sourceAnnotation", sourceAnnotation => new JArray(sourceAnnotation) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "title", title => new JValue(title) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ReviewItemDiscrepancy reviewItemDiscrepancy) - { - var jsonObject = new JObject(); - jsonObject.Add("approvedBy", this.PropertySerializerMap["approvedBy"](reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](reviewItemDiscrepancy.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](reviewItemDiscrepancy.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classification", this.PropertySerializerMap["classification"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationClassificationKind), reviewItemDiscrepancy.Classification))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), reviewItemDiscrepancy.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](reviewItemDiscrepancy.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](reviewItemDiscrepancy.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](reviewItemDiscrepancy.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](reviewItemDiscrepancy.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](reviewItemDiscrepancy.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](reviewItemDiscrepancy.Owner)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](reviewItemDiscrepancy.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](reviewItemDiscrepancy.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](reviewItemDiscrepancy.ShortName)); - jsonObject.Add("solution", this.PropertySerializerMap["solution"](reviewItemDiscrepancy.Solution)); - jsonObject.Add("sourceAnnotation", this.PropertySerializerMap["sourceAnnotation"](reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.ReportingData.AnnotationStatusKind), reviewItemDiscrepancy.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](reviewItemDiscrepancy.ThingPreference)); - jsonObject.Add("title", this.PropertySerializerMap["title"](reviewItemDiscrepancy.Title)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "approvedby": + var allowedVersionsForApprovedBy = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("approvedBy"u8); + + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + var allowedVersionsForClassification = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassification.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classification"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "solution": + var allowedVersionsForSolution = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSolution.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("solution"u8); + + if(value is IEnumerable objectListSolution) + { + foreach(var solutionItem in objectListSolution.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); + } + } + + writer.WriteEndArray(); + break; + case "sourceannotation": + var allowedVersionsForSourceAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("sourceAnnotation"u8); + + if(value is IEnumerable objectListSourceAnnotation) + { + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + } + + writer.WriteEndArray(); + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "title": + var allowedVersionsForTitle = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForTitle.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("title"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ReviewItemDiscrepancy"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ReviewItemDiscrepancy reviewItemDiscrepancy) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ReviewItemDiscrepancy", nameof(thing)); } - var reviewItemDiscrepancy = thing as ReviewItemDiscrepancy; - if (reviewItemDiscrepancy == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ReviewItemDiscrepancy since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ReviewItemDiscrepancy."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); + + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); + + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(reviewItemDiscrepancy.Actor.HasValue) + { + writer.WriteStringValue(reviewItemDiscrepancy.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); + + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(reviewItemDiscrepancy); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs index ce2c6cb9e..4da2b357e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RuleVerificationList = CDP4Common.DTO.RuleVerificationList; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,692 @@ namespace CDP4JsonSerializer public class RuleVerificationListSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "ruleVerification", ruleVerification => new JArray(((IEnumerable)ruleVerification).Cast().Select(x => x.ToJsonObject())) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RuleVerificationList ruleVerificationList) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](ruleVerificationList.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), ruleVerificationList.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](ruleVerificationList.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](ruleVerificationList.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](ruleVerificationList.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](ruleVerificationList.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](ruleVerificationList.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](ruleVerificationList.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](ruleVerificationList.RevisionNumber)); - jsonObject.Add("ruleVerification", this.PropertySerializerMap["ruleVerification"](ruleVerificationList.RuleVerification.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](ruleVerificationList.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](ruleVerificationList.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ruleverification": + var allowedVersionsForRuleVerification = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRuleVerification.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("ruleVerification"u8); + + if(value is IEnumerable objectListRuleVerification) + { + foreach(var ruleVerificationItem in objectListRuleVerification.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } + } + + writer.WriteEndArray(); + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RuleVerificationList"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RuleVerificationList ruleVerificationList) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a RuleVerificationList", nameof(thing)); } - var ruleVerificationList = thing as RuleVerificationList; - if (ruleVerificationList == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a RuleVerificationList."); + Logger.Log(LogLevel.Info, "Skipping serialization of RuleVerificationList since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); + + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); + + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); + + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleVerificationList.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ruleVerificationList.Actor.HasValue) + { + writer.WriteStringValue(ruleVerificationList.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); + + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleVerificationList.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(ruleVerificationList); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs index 839fe1599..e7f25e745 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using RuleViolation = CDP4Common.DTO.RuleViolation; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,450 @@ namespace CDP4JsonSerializer public class RuleViolationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "description", description => new JValue(description) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "violatingThing", violatingThing => new JArray(violatingThing) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(RuleViolation ruleViolation) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), ruleViolation.ClassKind))); - jsonObject.Add("description", this.PropertySerializerMap["description"](ruleViolation.Description)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](ruleViolation.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](ruleViolation.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](ruleViolation.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](ruleViolation.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](ruleViolation.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](ruleViolation.ThingPreference)); - jsonObject.Add("violatingThing", this.PropertySerializerMap["violatingThing"](ruleViolation.ViolatingThing.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "description": + var allowedVersionsForDescription = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDescription.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("description"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "violatingthing": + var allowedVersionsForViolatingThing = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForViolatingThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("violatingThing"u8); + + if(value is IEnumerable objectListViolatingThing) + { + foreach(var violatingThingItem in objectListViolatingThing) + { + writer.WriteStringValue((Guid)violatingThingItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the RuleViolation"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not RuleViolation ruleViolation) + { + throw new ArgumentException("The thing shall be a RuleViolation", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of RuleViolation since Version is below 1.0.0"); + return; } - var ruleViolation = thing as RuleViolation; - if (ruleViolation == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a RuleViolation."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleViolation.ThingPreference); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ruleViolation.Actor.HasValue) + { + writer.WriteStringValue(ruleViolation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleViolation.ThingPreference); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(ruleViolation); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs index f0483dd49..1ba4dc61f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SampledFunctionParameterType = CDP4Common.DTO.SampledFunctionParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,89 +50,730 @@ namespace CDP4JsonSerializer public class SampledFunctionParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "degreeOfInterpolation", degreeOfInterpolation => new JValue(degreeOfInterpolation) }, - { "dependentParameterType", dependentParameterType => new JArray(((IEnumerable)dependentParameterType).Cast().Select(x => x.ToJsonObject())) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "independentParameterType", independentParameterType => new JArray(((IEnumerable)independentParameterType).Cast().Select(x => x.ToJsonObject())) }, - { "interpolationPeriod", interpolationPeriod => new JValue(((ValueArray)interpolationPeriod).ToJsonString()) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SampledFunctionParameterType sampledFunctionParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](sampledFunctionParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](sampledFunctionParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), sampledFunctionParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](sampledFunctionParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("degreeOfInterpolation", this.PropertySerializerMap["degreeOfInterpolation"](sampledFunctionParameterType.DegreeOfInterpolation)); - jsonObject.Add("dependentParameterType", this.PropertySerializerMap["dependentParameterType"](sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](sampledFunctionParameterType.Iid)); - jsonObject.Add("independentParameterType", this.PropertySerializerMap["independentParameterType"](sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("interpolationPeriod", this.PropertySerializerMap["interpolationPeriod"](sampledFunctionParameterType.InterpolationPeriod)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](sampledFunctionParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](sampledFunctionParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](sampledFunctionParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](sampledFunctionParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](sampledFunctionParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](sampledFunctionParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](sampledFunctionParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "degreeofinterpolation": + var allowedVersionsForDegreeOfInterpolation = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDegreeOfInterpolation.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("degreeOfInterpolation"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "dependentparametertype": + var allowedVersionsForDependentParameterType = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDependentParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("dependentParameterType"u8); + + if(value is IEnumerable objectListDependentParameterType) + { + foreach(var dependentParameterTypeItem in objectListDependentParameterType.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dependentParameterTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "independentparametertype": + var allowedVersionsForIndependentParameterType = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIndependentParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("independentParameterType"u8); + + if(value is IEnumerable objectListIndependentParameterType) + { + foreach(var independentParameterTypeItem in objectListIndependentParameterType.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(independentParameterTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "interpolationperiod": + var allowedVersionsForInterpolationPeriod = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForInterpolationPeriod.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("interpolationPeriod"u8, ((ValueArray)value).ToJsonString()); + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SampledFunctionParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SampledFunctionParameterType sampledFunctionParameterType) + { + throw new ArgumentException("The thing shall be a SampledFunctionParameterType", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SampledFunctionParameterType since Version is below 1.2.0"); + return; } - var sampledFunctionParameterType = thing as SampledFunctionParameterType; - if (sampledFunctionParameterType == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SampledFunctionParameterType."); + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SampledFunctionParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("degreeOfInterpolation"u8); + + if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) + { + writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("dependentParameterType"u8); + + foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dependentParameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sampledFunctionParameterType.Iid); + writer.WriteStartArray("independentParameterType"u8); + + foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(independentParameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sampledFunctionParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(sampledFunctionParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(sampledFunctionParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SampledFunctionParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(sampledFunctionParameterType.Actor.HasValue) + { + writer.WriteStringValue(sampledFunctionParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("degreeOfInterpolation"u8); + + if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) + { + writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("dependentParameterType"u8); + + foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dependentParameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sampledFunctionParameterType.Iid); + writer.WriteStartArray("independentParameterType"u8); + + foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(independentParameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sampledFunctionParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(sampledFunctionParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(sampledFunctionParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(sampledFunctionParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs index c775a39a0..e65485253 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ScaleReferenceQuantityValue = CDP4Common.DTO.ScaleReferenceQuantityValue; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class ScaleReferenceQuantityValueSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(value) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ScaleReferenceQuantityValue scaleReferenceQuantityValue) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), scaleReferenceQuantityValue.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](scaleReferenceQuantityValue.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](scaleReferenceQuantityValue.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](scaleReferenceQuantityValue.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](scaleReferenceQuantityValue.Scale)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](scaleReferenceQuantityValue.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](scaleReferenceQuantityValue.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("value"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ScaleReferenceQuantityValue"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ScaleReferenceQuantityValue scaleReferenceQuantityValue) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a ScaleReferenceQuantityValue", nameof(thing)); } - var scaleReferenceQuantityValue = thing as ScaleReferenceQuantityValue; - if (scaleReferenceQuantityValue == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ScaleReferenceQuantityValue since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ScaleReferenceQuantityValue."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(scaleReferenceQuantityValue.Actor.HasValue) + { + writer.WriteStringValue(scaleReferenceQuantityValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(scaleReferenceQuantityValue); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs index 54efd1fa7..492f146e2 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ScaleValueDefinition = CDP4Common.DTO.ScaleValueDefinition; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,634 @@ namespace CDP4JsonSerializer public class ScaleValueDefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(value) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ScaleValueDefinition scaleValueDefinition) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](scaleValueDefinition.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), scaleValueDefinition.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](scaleValueDefinition.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](scaleValueDefinition.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](scaleValueDefinition.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](scaleValueDefinition.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](scaleValueDefinition.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](scaleValueDefinition.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](scaleValueDefinition.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](scaleValueDefinition.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](scaleValueDefinition.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("value"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ScaleValueDefinition"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ScaleValueDefinition scaleValueDefinition) + { + throw new ArgumentException("The thing shall be a ScaleValueDefinition", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ScaleValueDefinition since Version is below 1.0.0"); + return; } - var scaleValueDefinition = thing as ScaleValueDefinition; - if (scaleValueDefinition == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ScaleValueDefinition."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleValueDefinition.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(scaleValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleValueDefinition.Value); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(scaleValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleValueDefinition.Value); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(scaleValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleValueDefinition.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleValueDefinition.Value); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(scaleValueDefinition.Actor.HasValue) + { + writer.WriteStringValue(scaleValueDefinition.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(scaleValueDefinition.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleValueDefinition.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleValueDefinition.Value); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(scaleValueDefinition); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs index b915c1d23..49fb9fa52 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Section = CDP4Common.DTO.Section; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,568 @@ namespace CDP4JsonSerializer public class SectionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "page", page => new JArray(((IEnumerable)page).Cast().Select(x => x.ToJsonObject())) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Section section) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](section.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), section.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](section.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](section.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](section.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](section.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](section.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](section.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](section.Owner)); - jsonObject.Add("page", this.PropertySerializerMap["page"](section.Page.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](section.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](section.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](section.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "page": + var allowedVersionsForPage = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPage.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("page"u8); + + if(value is IEnumerable objectListPage) + { + foreach(var pageItem in objectListPage.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Section"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Section section) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Section", nameof(thing)); } - var section = thing as Section; - if (section == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a Section."); + Logger.Log(LogLevel.Info, "Skipping serialization of Section since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(section.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(section.Actor.HasValue) + { + writer.WriteStringValue(section.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(section.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(section); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SerializerProvider.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SerializerProvider.cs index 723578ffb..e638d2d62 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SerializerProvider.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SerializerProvider.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2023 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -30,14 +30,13 @@ namespace CDP4JsonSerializer { using System; using System.Collections.Generic; - + using System.Text.Json; + using CDP4Common; using CDP4Common.DTO; - + using CDP4JsonSerializer.Helper; - using Newtonsoft.Json.Linq; - /// /// A static class that provides method to serialize a or a /// @@ -46,7 +45,7 @@ public static class SerializerProvider /// /// The map containing the Serializers /// - private static readonly Dictionary SerializerMap = new Dictionary + private static readonly Dictionary SerializerMap = new() { { "ActionItem", new ActionItemSerializer() }, { "ActualFiniteState", new ActualFiniteStateSerializer() }, @@ -197,42 +196,43 @@ public static class SerializerProvider }; /// - /// Serialize a + /// Serialize a into an /// /// The - /// The - public static JObject ToJsonObject(this Thing thing) + /// The + /// The that has been requested for the serialization + public static void SerializeThing(this Thing thing, Utf8JsonWriter writer, Version requestedVersion) { - IThingSerializer serializer; - if(!SerializerMap.TryGetValue(thing.ClassKind.ToString(), out serializer)) + if(!SerializerMap.TryGetValue(thing.ClassKind.ToString(), out var serializer)) { throw new NotSupportedException($"The {thing.ClassKind} class is not registered"); } - - return serializer.Serialize(thing); + + serializer.Serialize(thing, writer, requestedVersion); } - + /// - /// Serialize a + /// Serialize a into an /// /// The - /// The - public static JObject ToJsonObject(this ClasslessDTO classlessDto) + /// The + /// The that has been requested for the serialization + public static void SerializeClasslessDto(this ClasslessDTO classlessDto, Utf8JsonWriter writer, Version requestedVersion) { - IThingSerializer serializer; - if(!SerializerMap.TryGetValue(classlessDto["ClassKind"].ToString(), out serializer)) + if(!SerializerMap.TryGetValue(classlessDto["ClassKind"].ToString(), out var serializer)) { throw new NotSupportedException($"The {classlessDto["ClassKind"]} class is not registered"); } - var jsonObject = new JObject(); + writer.WriteStartObject(); + foreach (var keyValue in classlessDto) { var key = Utils.LowercaseFirstLetter(keyValue.Key); - jsonObject.Add(key, serializer.PropertySerializerMap[key](keyValue.Value)); + serializer.SerializeProperty(key, keyValue.Value, writer, requestedVersion); } - return jsonObject; + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs index f11e71715..c5318bfc6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SharedStyle = CDP4Common.DTO.SharedStyle; /// /// The purpose of the class is to provide a specific serializer @@ -44,93 +50,1095 @@ namespace CDP4JsonSerializer public class SharedStyleSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fillColor", fillColor => new JValue(fillColor) }, - { "fillOpacity", fillOpacity => new JValue(fillOpacity) }, - { "fontBold", fontBold => new JValue(fontBold) }, - { "fontColor", fontColor => new JValue(fontColor) }, - { "fontItalic", fontItalic => new JValue(fontItalic) }, - { "fontName", fontName => new JValue(fontName) }, - { "fontSize", fontSize => new JValue(fontSize) }, - { "fontStrokeThrough", fontStrokeThrough => new JValue(fontStrokeThrough) }, - { "fontUnderline", fontUnderline => new JValue(fontUnderline) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "strokeColor", strokeColor => new JValue(strokeColor) }, - { "strokeOpacity", strokeOpacity => new JValue(strokeOpacity) }, - { "strokeWidth", strokeWidth => new JValue(strokeWidth) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "usedColor", usedColor => new JArray(usedColor) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SharedStyle sharedStyle) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), sharedStyle.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](sharedStyle.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](sharedStyle.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fillColor", this.PropertySerializerMap["fillColor"](sharedStyle.FillColor)); - jsonObject.Add("fillOpacity", this.PropertySerializerMap["fillOpacity"](sharedStyle.FillOpacity)); - jsonObject.Add("fontBold", this.PropertySerializerMap["fontBold"](sharedStyle.FontBold)); - jsonObject.Add("fontColor", this.PropertySerializerMap["fontColor"](sharedStyle.FontColor)); - jsonObject.Add("fontItalic", this.PropertySerializerMap["fontItalic"](sharedStyle.FontItalic)); - jsonObject.Add("fontName", this.PropertySerializerMap["fontName"](sharedStyle.FontName)); - jsonObject.Add("fontSize", this.PropertySerializerMap["fontSize"](sharedStyle.FontSize)); - jsonObject.Add("fontStrokeThrough", this.PropertySerializerMap["fontStrokeThrough"](sharedStyle.FontStrokeThrough)); - jsonObject.Add("fontUnderline", this.PropertySerializerMap["fontUnderline"](sharedStyle.FontUnderline)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](sharedStyle.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](sharedStyle.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](sharedStyle.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](sharedStyle.RevisionNumber)); - jsonObject.Add("strokeColor", this.PropertySerializerMap["strokeColor"](sharedStyle.StrokeColor)); - jsonObject.Add("strokeOpacity", this.PropertySerializerMap["strokeOpacity"](sharedStyle.StrokeOpacity)); - jsonObject.Add("strokeWidth", this.PropertySerializerMap["strokeWidth"](sharedStyle.StrokeWidth)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](sharedStyle.ThingPreference)); - jsonObject.Add("usedColor", this.PropertySerializerMap["usedColor"](sharedStyle.UsedColor.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "fillcolor": + var allowedVersionsForFillColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFillColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fillopacity": + var allowedVersionsForFillOpacity = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFillOpacity.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillOpacity"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontbold": + var allowedVersionsForFontBold = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontBold.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontBold"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontcolor": + var allowedVersionsForFontColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontitalic": + var allowedVersionsForFontItalic = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontItalic.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontItalic"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontname": + var allowedVersionsForFontName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontsize": + var allowedVersionsForFontSize = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontSize.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontSize"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontstrokethrough": + var allowedVersionsForFontStrokeThrough = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontStrokeThrough.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "fontunderline": + var allowedVersionsForFontUnderline = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFontUnderline.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fontUnderline"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokecolor": + var allowedVersionsForStrokeColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeColor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokeopacity": + var allowedVersionsForStrokeOpacity = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeOpacity.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "strokewidth": + var allowedVersionsForStrokeWidth = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStrokeWidth.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("strokeWidth"u8); + + if(value != null) + { + writer.WriteNumberValue((float)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "usedcolor": + var allowedVersionsForUsedColor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUsedColor.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("usedColor"u8); + + if(value is IEnumerable objectListUsedColor) + { + foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SharedStyle"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SharedStyle sharedStyle) + { + throw new ArgumentException("The thing shall be a SharedStyle", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SharedStyle since Version is below 1.1.0"); + return; } - var sharedStyle = thing as SharedStyle; - if (sharedStyle == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SharedStyle."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sharedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sharedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(sharedStyle.FillColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(sharedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(sharedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(sharedStyle.FontColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(sharedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(sharedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(sharedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(sharedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(sharedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(sharedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sharedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sharedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sharedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(sharedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(sharedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(sharedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(sharedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sharedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sharedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(sharedStyle.FillColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(sharedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(sharedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(sharedStyle.FontColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(sharedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(sharedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(sharedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(sharedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(sharedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(sharedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sharedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sharedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sharedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(sharedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(sharedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(sharedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(sharedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sharedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(sharedStyle.Actor.HasValue) + { + writer.WriteStringValue(sharedStyle.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sharedStyle.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sharedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); + + if(sharedStyle.FillColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FillColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fillOpacity"u8); + + if(sharedStyle.FillOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.FillOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontBold"u8); + + if(sharedStyle.FontBold.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontBold.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontColor"u8); + + if(sharedStyle.FontColor.HasValue) + { + writer.WriteStringValue(sharedStyle.FontColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontItalic"u8); + + if(sharedStyle.FontItalic.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontItalic.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(sharedStyle.FontName); + writer.WritePropertyName("fontSize"u8); + + if(sharedStyle.FontSize.HasValue) + { + writer.WriteNumberValue(sharedStyle.FontSize.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontStrokeThrough"u8); + + if(sharedStyle.FontStrokeThrough.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontStrokeThrough.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("fontUnderline"u8); + + if(sharedStyle.FontUnderline.HasValue) + { + writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sharedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sharedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sharedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(sharedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(sharedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(sharedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(sharedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sharedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(sharedStyle); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs index 4b70f6b93..f8aae430a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SimpleParameterValue = CDP4Common.DTO.SimpleParameterValue; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,482 @@ namespace CDP4JsonSerializer public class SimpleParameterValueSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "parameterType", parameterType => new JValue(parameterType) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "scale", scale => new JValue(scale) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(((ValueArray)value).ToJsonString()) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SimpleParameterValue simpleParameterValue) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), simpleParameterValue.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](simpleParameterValue.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](simpleParameterValue.ModifiedOn)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](simpleParameterValue.ParameterType)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](simpleParameterValue.RevisionNumber)); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](simpleParameterValue.Scale)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](simpleParameterValue.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](simpleParameterValue.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("parameterType"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("scale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleParameterValue"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SimpleParameterValue simpleParameterValue) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SimpleParameterValue", nameof(thing)); } - var simpleParameterValue = thing as SimpleParameterValue; - if (simpleParameterValue == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a SimpleParameterValue."); + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleParameterValue since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleParameterValue.ThingPreference); + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(simpleParameterValue.Actor.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleParameterValue.ThingPreference); + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(simpleParameterValue); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs index fac2f56b2..d1564944c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SimpleQuantityKind = CDP4Common.DTO.SimpleQuantityKind; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,852 @@ namespace CDP4JsonSerializer public class SimpleQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultScale", defaultScale => new JValue(defaultScale) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "possibleScale", possibleScale => new JArray(possibleScale) }, - { "quantityDimensionSymbol", quantityDimensionSymbol => new JValue(quantityDimensionSymbol) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SimpleQuantityKind simpleQuantityKind) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](simpleQuantityKind.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](simpleQuantityKind.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), simpleQuantityKind.ClassKind))); - jsonObject.Add("defaultScale", this.PropertySerializerMap["defaultScale"](simpleQuantityKind.DefaultScale)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](simpleQuantityKind.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](simpleQuantityKind.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](simpleQuantityKind.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](simpleQuantityKind.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](simpleQuantityKind.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](simpleQuantityKind.Name)); - jsonObject.Add("possibleScale", this.PropertySerializerMap["possibleScale"](simpleQuantityKind.PossibleScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("quantityDimensionSymbol", this.PropertySerializerMap["quantityDimensionSymbol"](simpleQuantityKind.QuantityDimensionSymbol)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](simpleQuantityKind.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](simpleQuantityKind.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](simpleQuantityKind.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](simpleQuantityKind.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultscale": + var allowedVersionsForDefaultScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultScale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblescale": + var allowedVersionsForPossibleScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleScale"u8); + + if(value is IEnumerable objectListPossibleScale) + { + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "quantitydimensionsymbol": + var allowedVersionsForQuantityDimensionSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleQuantityKind"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SimpleQuantityKind simpleQuantityKind) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SimpleQuantityKind", nameof(thing)); } - var simpleQuantityKind = thing as SimpleQuantityKind; - if (simpleQuantityKind == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleQuantityKind since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SimpleQuantityKind."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleQuantityKind.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(simpleQuantityKind.Actor.HasValue) + { + writer.WriteStringValue(simpleQuantityKind.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleQuantityKind.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(simpleQuantityKind); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs index 4cf8ffb62..37ce4c2b7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SimpleUnit = CDP4Common.DTO.SimpleUnit; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,634 @@ namespace CDP4JsonSerializer public class SimpleUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SimpleUnit simpleUnit) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](simpleUnit.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), simpleUnit.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](simpleUnit.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](simpleUnit.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](simpleUnit.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](simpleUnit.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](simpleUnit.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](simpleUnit.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](simpleUnit.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](simpleUnit.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](simpleUnit.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](simpleUnit.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](simpleUnit.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleUnit"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SimpleUnit simpleUnit) + { + throw new ArgumentException("The thing shall be a SimpleUnit", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleUnit since Version is below 1.0.0"); + return; } - var simpleUnit = thing as SimpleUnit; - if (simpleUnit == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SimpleUnit."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleUnit.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleUnit.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleUnit.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleUnit.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(simpleUnit.Actor.HasValue) + { + writer.WriteStringValue(simpleUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleUnit.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(simpleUnit); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs index 92fdee2df..91fb72ddb 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteDirectoryDataAnnotation = CDP4Common.DTO.SiteDirectoryDataAnnotation; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,599 @@ namespace CDP4JsonSerializer public class SiteDirectoryDataAnnotationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "discussion", discussion => new JArray(discussion) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "primaryAnnotatedThing", primaryAnnotatedThing => new JValue(primaryAnnotatedThing) }, - { "relatedThing", relatedThing => new JArray(relatedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteDirectoryDataAnnotation siteDirectoryDataAnnotation) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](siteDirectoryDataAnnotation.Author)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteDirectoryDataAnnotation.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](siteDirectoryDataAnnotation.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](siteDirectoryDataAnnotation.CreatedOn)); - jsonObject.Add("discussion", this.PropertySerializerMap["discussion"](siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteDirectoryDataAnnotation.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](siteDirectoryDataAnnotation.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteDirectoryDataAnnotation.ModifiedOn)); - jsonObject.Add("primaryAnnotatedThing", this.PropertySerializerMap["primaryAnnotatedThing"](siteDirectoryDataAnnotation.PrimaryAnnotatedThing)); - jsonObject.Add("relatedThing", this.PropertySerializerMap["relatedThing"](siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteDirectoryDataAnnotation.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteDirectoryDataAnnotation.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "discussion": + var allowedVersionsForDiscussion = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "primaryannotatedthing": + var allowedVersionsForPrimaryAnnotatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "relatedthing": + var allowedVersionsForRelatedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("relatedThing"u8); + + if(value is IEnumerable objectListRelatedThing) + { + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectoryDataAnnotation"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteDirectoryDataAnnotation siteDirectoryDataAnnotation) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SiteDirectoryDataAnnotation", nameof(thing)); } - var siteDirectoryDataAnnotation = thing as SiteDirectoryDataAnnotation; - if (siteDirectoryDataAnnotation == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataAnnotation since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SiteDirectoryDataAnnotation."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryDataAnnotation.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryDataAnnotation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteDirectoryDataAnnotation); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs index 2f12b765d..b04f9b5d1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteDirectoryDataDiscussionItem = CDP4Common.DTO.SiteDirectoryDataDiscussionItem; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,528 @@ namespace CDP4JsonSerializer public class SiteDirectoryDataDiscussionItemSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "replyTo", replyTo => new JValue(replyTo) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteDirectoryDataDiscussionItem siteDirectoryDataDiscussionItem) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](siteDirectoryDataDiscussionItem.Author)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteDirectoryDataDiscussionItem.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](siteDirectoryDataDiscussionItem.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](siteDirectoryDataDiscussionItem.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteDirectoryDataDiscussionItem.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](siteDirectoryDataDiscussionItem.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteDirectoryDataDiscussionItem.ModifiedOn)); - jsonObject.Add("replyTo", this.PropertySerializerMap["replyTo"](siteDirectoryDataDiscussionItem.ReplyTo)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteDirectoryDataDiscussionItem.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteDirectoryDataDiscussionItem.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "replyto": + var allowedVersionsForReplyTo = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReplyTo.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("replyTo"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectoryDataDiscussionItem"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteDirectoryDataDiscussionItem siteDirectoryDataDiscussionItem) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SiteDirectoryDataDiscussionItem", nameof(thing)); } - var siteDirectoryDataDiscussionItem = thing as SiteDirectoryDataDiscussionItem; - if (siteDirectoryDataDiscussionItem == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a SiteDirectoryDataDiscussionItem."); + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataDiscussionItem since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryDataDiscussionItem.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteDirectoryDataDiscussionItem); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs index f29372de4..0b02b53b6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteDirectory = CDP4Common.DTO.SiteDirectory; /// /// The purpose of the class is to provide a specific serializer @@ -44,99 +50,1263 @@ namespace CDP4JsonSerializer public class SiteDirectorySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "annotation", annotation => new JArray(annotation) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "defaultParticipantRole", defaultParticipantRole => new JValue(defaultParticipantRole) }, - { "defaultPersonRole", defaultPersonRole => new JValue(defaultPersonRole) }, - { "domain", domain => new JArray(domain) }, - { "domainGroup", domainGroup => new JArray(domainGroup) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "lastModifiedOn", lastModifiedOn => new JValue(((DateTime)lastModifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "logEntry", logEntry => new JArray(logEntry) }, - { "model", model => new JArray(model) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "naturalLanguage", naturalLanguage => new JArray(naturalLanguage) }, - { "organization", organization => new JArray(organization) }, - { "participantRole", participantRole => new JArray(participantRole) }, - { "person", person => new JArray(person) }, - { "personRole", personRole => new JArray(personRole) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "siteReferenceDataLibrary", siteReferenceDataLibrary => new JArray(siteReferenceDataLibrary) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteDirectory siteDirectory) - { - var jsonObject = new JObject(); - jsonObject.Add("annotation", this.PropertySerializerMap["annotation"](siteDirectory.Annotation.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteDirectory.ClassKind))); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](siteDirectory.CreatedOn)); - jsonObject.Add("defaultParticipantRole", this.PropertySerializerMap["defaultParticipantRole"](siteDirectory.DefaultParticipantRole)); - jsonObject.Add("defaultPersonRole", this.PropertySerializerMap["defaultPersonRole"](siteDirectory.DefaultPersonRole)); - jsonObject.Add("domain", this.PropertySerializerMap["domain"](siteDirectory.Domain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("domainGroup", this.PropertySerializerMap["domainGroup"](siteDirectory.DomainGroup.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteDirectory.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteDirectory.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteDirectory.Iid)); - jsonObject.Add("lastModifiedOn", this.PropertySerializerMap["lastModifiedOn"](siteDirectory.LastModifiedOn)); - jsonObject.Add("logEntry", this.PropertySerializerMap["logEntry"](siteDirectory.LogEntry.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("model", this.PropertySerializerMap["model"](siteDirectory.Model.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteDirectory.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](siteDirectory.Name)); - jsonObject.Add("naturalLanguage", this.PropertySerializerMap["naturalLanguage"](siteDirectory.NaturalLanguage.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("organization", this.PropertySerializerMap["organization"](siteDirectory.Organization.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("participantRole", this.PropertySerializerMap["participantRole"](siteDirectory.ParticipantRole.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("person", this.PropertySerializerMap["person"](siteDirectory.Person.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("personRole", this.PropertySerializerMap["personRole"](siteDirectory.PersonRole.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteDirectory.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](siteDirectory.ShortName)); - jsonObject.Add("siteReferenceDataLibrary", this.PropertySerializerMap["siteReferenceDataLibrary"](siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteDirectory.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "annotation": + var allowedVersionsForAnnotation = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAnnotation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("annotation"u8); + + if(value is IEnumerable objectListAnnotation) + { + foreach(var annotationItem in objectListAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(annotationItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultparticipantrole": + var allowedVersionsForDefaultParticipantRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultParticipantRole.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultParticipantRole"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultpersonrole": + var allowedVersionsForDefaultPersonRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultPersonRole.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultPersonRole"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "domain": + var allowedVersionsForDomain = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domain"u8); + + if(value is IEnumerable objectListDomain) + { + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + } + + writer.WriteEndArray(); + break; + case "domaingroup": + var allowedVersionsForDomainGroup = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDomainGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("domainGroup"u8); + + if(value is IEnumerable objectListDomainGroup) + { + foreach(var domainGroupItem in objectListDomainGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "lastmodifiedon": + var allowedVersionsForLastModifiedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLastModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("lastModifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logentry": + var allowedVersionsForLogEntry = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLogEntry.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("logEntry"u8); + + if(value is IEnumerable objectListLogEntry) + { + foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + } + + writer.WriteEndArray(); + break; + case "model": + var allowedVersionsForModel = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModel.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("model"u8); + + if(value is IEnumerable objectListModel) + { + foreach(var modelItem in objectListModel.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "naturallanguage": + var allowedVersionsForNaturalLanguage = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForNaturalLanguage.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("naturalLanguage"u8); + + if(value is IEnumerable objectListNaturalLanguage) + { + foreach(var naturalLanguageItem in objectListNaturalLanguage.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } + } + + writer.WriteEndArray(); + break; + case "organization": + var allowedVersionsForOrganization = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOrganization.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("organization"u8); + + if(value is IEnumerable objectListOrganization) + { + foreach(var organizationItem in objectListOrganization.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } + } + + writer.WriteEndArray(); + break; + case "participantrole": + var allowedVersionsForParticipantRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParticipantRole.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("participantRole"u8); + + if(value is IEnumerable objectListParticipantRole) + { + foreach(var participantRoleItem in objectListParticipantRole.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } + } + + writer.WriteEndArray(); + break; + case "person": + var allowedVersionsForPerson = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("person"u8); + + if(value is IEnumerable objectListPerson) + { + foreach(var personItem in objectListPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } + } + + writer.WriteEndArray(); + break; + case "personrole": + var allowedVersionsForPersonRole = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPersonRole.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("personRole"u8); + + if(value is IEnumerable objectListPersonRole) + { + foreach(var personRoleItem in objectListPersonRole.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "sitereferencedatalibrary": + var allowedVersionsForSiteReferenceDataLibrary = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSiteReferenceDataLibrary.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + if(value is IEnumerable objectListSiteReferenceDataLibrary) + { + foreach(var siteReferenceDataLibraryItem in objectListSiteReferenceDataLibrary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectory"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteDirectory siteDirectory) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SiteDirectory", nameof(thing)); } - var siteDirectory = thing as SiteDirectory; - if (siteDirectory == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a SiteDirectory."); + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectory since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultPersonRole"u8); + + if(siteDirectory.DefaultPersonRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainGroup"u8); + + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("model"u8); + + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); + + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("organization"u8); + + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participantRole"u8); + + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("person"u8); + + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("personRole"u8); + + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.1.0"); + writer.WriteStartArray("annotation"u8); + + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(annotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultPersonRole"u8); + + if(siteDirectory.DefaultPersonRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainGroup"u8); + + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("model"u8); + + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); + + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("organization"u8); + + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participantRole"u8); + + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("person"u8); + + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("personRole"u8); + + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.2.0"); + writer.WriteStartArray("annotation"u8); + + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(annotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultPersonRole"u8); + + if(siteDirectory.DefaultPersonRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainGroup"u8); + + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("model"u8); + + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); + + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("organization"u8); + + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participantRole"u8); + + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("person"u8); + + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("personRole"u8); + + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectory.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectory.Actor.HasValue) + { + writer.WriteStringValue(siteDirectory.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("annotation"u8); + + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(annotationItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("defaultPersonRole"u8); + + if(siteDirectory.DefaultPersonRole.HasValue) + { + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainGroup"u8); + + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("model"u8); + + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); + + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("organization"u8); + + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("participantRole"u8); + + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("person"u8); + + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("personRole"u8); + + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectory.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteDirectory); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs index 2b33b4e6b..22b0c2310 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteDirectoryThingReference = CDP4Common.DTO.SiteDirectoryThingReference; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,408 @@ namespace CDP4JsonSerializer public class SiteDirectoryThingReferenceSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "referencedRevisionNumber", referencedRevisionNumber => new JValue(referencedRevisionNumber) }, - { "referencedThing", referencedThing => new JValue(referencedThing) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteDirectoryThingReference siteDirectoryThingReference) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteDirectoryThingReference.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteDirectoryThingReference.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteDirectoryThingReference.ModifiedOn)); - jsonObject.Add("referencedRevisionNumber", this.PropertySerializerMap["referencedRevisionNumber"](siteDirectoryThingReference.ReferencedRevisionNumber)); - jsonObject.Add("referencedThing", this.PropertySerializerMap["referencedThing"](siteDirectoryThingReference.ReferencedThing)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteDirectoryThingReference.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteDirectoryThingReference.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencedrevisionnumber": + var allowedVersionsForReferencedRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referencedRevisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referencedthing": + var allowedVersionsForReferencedThing = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferencedThing.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("referencedThing"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectoryThingReference"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteDirectoryThingReference siteDirectoryThingReference) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a SiteDirectoryThingReference", nameof(thing)); } - var siteDirectoryThingReference = thing as SiteDirectoryThingReference; - if (siteDirectoryThingReference == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryThingReference since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SiteDirectoryThingReference."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryThingReference.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryThingReference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteDirectoryThingReference); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs index b5912bc0b..89790245c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteLogEntry = CDP4Common.DTO.SiteLogEntry; /// /// The purpose of the class is to provide a specific serializer @@ -44,83 +50,778 @@ namespace CDP4JsonSerializer public class SiteLogEntrySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "affectedDomainIid", affectedDomainIid => new JArray(affectedDomainIid) }, - { "affectedItemIid", affectedItemIid => new JArray(affectedItemIid) }, - { "author", author => new JValue(author) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "level", level => new JValue(level.ToString()) }, - { "logEntryChangelogItem", logEntryChangelogItem => new JArray(logEntryChangelogItem) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteLogEntry siteLogEntry) - { - var jsonObject = new JObject(); - jsonObject.Add("affectedDomainIid", this.PropertySerializerMap["affectedDomainIid"](siteLogEntry.AffectedDomainIid.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("affectedItemIid", this.PropertySerializerMap["affectedItemIid"](siteLogEntry.AffectedItemIid.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("author", this.PropertySerializerMap["author"](siteLogEntry.Author)); - jsonObject.Add("category", this.PropertySerializerMap["category"](siteLogEntry.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteLogEntry.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](siteLogEntry.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](siteLogEntry.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteLogEntry.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteLogEntry.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteLogEntry.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](siteLogEntry.LanguageCode)); - jsonObject.Add("level", this.PropertySerializerMap["level"](Enum.GetName(typeof(CDP4Common.CommonData.LogLevelKind), siteLogEntry.Level))); - jsonObject.Add("logEntryChangelogItem", this.PropertySerializerMap["logEntryChangelogItem"](siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteLogEntry.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteLogEntry.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteLogEntry.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "affecteddomainiid": + var allowedVersionsForAffectedDomainIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedDomainIid.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("affectedDomainIid"u8); + + if(value is IEnumerable objectListAffectedDomainIid) + { + foreach(var affectedDomainIidItem in objectListAffectedDomainIid) + { + writer.WriteStringValue((Guid)affectedDomainIidItem); + } + } + + writer.WriteEndArray(); + break; + case "affecteditemiid": + var allowedVersionsForAffectedItemIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("affectedItemIid"u8); + + if(value is IEnumerable objectListAffectedItemIid) + { + foreach(var affectedItemIidItem in objectListAffectedItemIid) + { + writer.WriteStringValue((Guid)affectedItemIidItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "level": + var allowedVersionsForLevel = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLevel.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("level"u8); + + if(value != null) + { + writer.WriteStringValue(((LogLevelKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logentrychangelogitem": + var allowedVersionsForLogEntryChangelogItem = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLogEntryChangelogItem.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("logEntryChangelogItem"u8); + + if(value is IEnumerable objectListLogEntryChangelogItem) + { + foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + } + + writer.WriteEndArray(); + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteLogEntry"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteLogEntry siteLogEntry) + { + throw new ArgumentException("The thing shall be a SiteLogEntry", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SiteLogEntry since Version is below 1.0.0"); + return; } - var siteLogEntry = thing as SiteLogEntry; - if (siteLogEntry == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SiteLogEntry."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.0.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) + { + writer.WriteStringValue(siteLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.1.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) + { + writer.WriteStringValue(siteLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.2.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) + { + writer.WriteStringValue(siteLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteLogEntry.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteLogEntry.Actor.HasValue) + { + writer.WriteStringValue(siteLogEntry.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) + { + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("affectedItemIid"u8); + + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + { + writer.WriteStringValue(affectedItemIidItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) + { + writer.WriteStringValue(siteLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteLogEntry.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteLogEntry); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs index ce4c3fe0d..138ecdcfc 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SiteReferenceDataLibrary = CDP4Common.DTO.SiteReferenceDataLibrary; /// /// The purpose of the class is to provide a specific serializer @@ -44,103 +50,1400 @@ namespace CDP4JsonSerializer public class SiteReferenceDataLibrarySerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "baseQuantityKind", baseQuantityKind => new JArray(((IEnumerable)baseQuantityKind).Cast().Select(x => x.ToJsonObject())) }, - { "baseUnit", baseUnit => new JArray(baseUnit) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "constant", constant => new JArray(constant) }, - { "definedCategory", definedCategory => new JArray(definedCategory) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "fileType", fileType => new JArray(fileType) }, - { "glossary", glossary => new JArray(glossary) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "parameterType", parameterType => new JArray(parameterType) }, - { "referenceSource", referenceSource => new JArray(referenceSource) }, - { "requiredRdl", requiredRdl => new JValue(requiredRdl) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "rule", rule => new JArray(rule) }, - { "scale", scale => new JArray(scale) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JArray(unit) }, - { "unitPrefix", unitPrefix => new JArray(unitPrefix) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SiteReferenceDataLibrary siteReferenceDataLibrary) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](siteReferenceDataLibrary.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("baseQuantityKind", this.PropertySerializerMap["baseQuantityKind"](siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.orderedItemComparer))); - jsonObject.Add("baseUnit", this.PropertySerializerMap["baseUnit"](siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), siteReferenceDataLibrary.ClassKind))); - jsonObject.Add("constant", this.PropertySerializerMap["constant"](siteReferenceDataLibrary.Constant.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("definedCategory", this.PropertySerializerMap["definedCategory"](siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](siteReferenceDataLibrary.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("fileType", this.PropertySerializerMap["fileType"](siteReferenceDataLibrary.FileType.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("glossary", this.PropertySerializerMap["glossary"](siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](siteReferenceDataLibrary.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](siteReferenceDataLibrary.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](siteReferenceDataLibrary.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](siteReferenceDataLibrary.Name)); - jsonObject.Add("parameterType", this.PropertySerializerMap["parameterType"](siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("referenceSource", this.PropertySerializerMap["referenceSource"](siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("requiredRdl", this.PropertySerializerMap["requiredRdl"](siteReferenceDataLibrary.RequiredRdl)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](siteReferenceDataLibrary.RevisionNumber)); - jsonObject.Add("rule", this.PropertySerializerMap["rule"](siteReferenceDataLibrary.Rule.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("scale", this.PropertySerializerMap["scale"](siteReferenceDataLibrary.Scale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](siteReferenceDataLibrary.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](siteReferenceDataLibrary.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](siteReferenceDataLibrary.Unit.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("unitPrefix", this.PropertySerializerMap["unitPrefix"](siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "basequantitykind": + var allowedVersionsForBaseQuantityKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBaseQuantityKind.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("baseQuantityKind"u8); + + if(value is IEnumerable objectListBaseQuantityKind) + { + foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + } + + writer.WriteEndArray(); + break; + case "baseunit": + var allowedVersionsForBaseUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForBaseUnit.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("baseUnit"u8); + + if(value is IEnumerable objectListBaseUnit) + { + foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "constant": + var allowedVersionsForConstant = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForConstant.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("constant"u8); + + if(value is IEnumerable objectListConstant) + { + foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + } + + writer.WriteEndArray(); + break; + case "definedcategory": + var allowedVersionsForDefinedCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinedCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definedCategory"u8); + + if(value is IEnumerable objectListDefinedCategory) + { + foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filetype": + var allowedVersionsForFileType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForFileType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("fileType"u8); + + if(value is IEnumerable objectListFileType) + { + foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "glossary": + var allowedVersionsForGlossary = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGlossary.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("glossary"u8); + + if(value is IEnumerable objectListGlossary) + { + foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "parametertype": + var allowedVersionsForParameterType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForParameterType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("parameterType"u8); + + if(value is IEnumerable objectListParameterType) + { + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + } + + writer.WriteEndArray(); + break; + case "referencesource": + var allowedVersionsForReferenceSource = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForReferenceSource.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("referenceSource"u8); + + if(value is IEnumerable objectListReferenceSource) + { + foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + } + + writer.WriteEndArray(); + break; + case "requiredrdl": + var allowedVersionsForRequiredRdl = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("requiredRdl"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "rule": + var allowedVersionsForRule = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRule.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("rule"u8); + + if(value is IEnumerable objectListRule) + { + foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + } + + writer.WriteEndArray(); + break; + case "scale": + var allowedVersionsForScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("scale"u8); + + if(value is IEnumerable objectListScale) + { + foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + } + + writer.WriteEndArray(); + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("unit"u8); + + if(value is IEnumerable objectListUnit) + { + foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + } + + writer.WriteEndArray(); + break; + case "unitprefix": + var allowedVersionsForUnitPrefix = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnitPrefix.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("unitPrefix"u8); + + if(value is IEnumerable objectListUnitPrefix) + { + foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteReferenceDataLibrary"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SiteReferenceDataLibrary siteReferenceDataLibrary) + { + throw new ArgumentException("The thing shall be a SiteReferenceDataLibrary", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SiteReferenceDataLibrary since Version is below 1.0.0"); + return; } - var siteReferenceDataLibrary = thing as SiteReferenceDataLibrary; - if (siteReferenceDataLibrary == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SiteReferenceDataLibrary."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteReferenceDataLibrary.Actor.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); + + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); + + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); + + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); + writer.WriteStartArray("unit"u8); + + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(siteReferenceDataLibrary); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs index 68a30823e..96fb334f7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Solution = CDP4Common.DTO.Solution; /// /// The purpose of the class is to provide a specific serializer @@ -44,75 +50,501 @@ namespace CDP4JsonSerializer public class SolutionSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "author", author => new JValue(author) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Solution solution) - { - var jsonObject = new JObject(); - jsonObject.Add("author", this.PropertySerializerMap["author"](solution.Author)); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), solution.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](solution.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](solution.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](solution.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](solution.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](solution.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](solution.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](solution.ModifiedOn)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](solution.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](solution.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](solution.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "author": + var allowedVersionsForAuthor = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAuthor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Solution"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Solution solution) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Solution", nameof(thing)); } - var solution = thing as Solution; - if (solution == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a Solution."); + Logger.Log(LogLevel.Info, "Skipping serialization of Solution since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(solution.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(solution.Actor.HasValue) + { + writer.WriteStringValue(solution.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(solution.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(solution); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs index 3e49c04b2..411b0211e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using SpecializedQuantityKind = CDP4Common.DTO.SpecializedQuantityKind; /// /// The purpose of the class is to provide a specific serializer @@ -44,89 +50,886 @@ namespace CDP4JsonSerializer public class SpecializedQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "defaultScale", defaultScale => new JValue(defaultScale) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "general", general => new JValue(general) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "possibleScale", possibleScale => new JArray(possibleScale) }, - { "quantityDimensionSymbol", quantityDimensionSymbol => new JValue(quantityDimensionSymbol) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(SpecializedQuantityKind specializedQuantityKind) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](specializedQuantityKind.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](specializedQuantityKind.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), specializedQuantityKind.ClassKind))); - jsonObject.Add("defaultScale", this.PropertySerializerMap["defaultScale"](specializedQuantityKind.DefaultScale)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](specializedQuantityKind.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("general", this.PropertySerializerMap["general"](specializedQuantityKind.General)); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](specializedQuantityKind.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](specializedQuantityKind.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](specializedQuantityKind.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](specializedQuantityKind.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](specializedQuantityKind.Name)); - jsonObject.Add("possibleScale", this.PropertySerializerMap["possibleScale"](specializedQuantityKind.PossibleScale.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("quantityDimensionSymbol", this.PropertySerializerMap["quantityDimensionSymbol"](specializedQuantityKind.QuantityDimensionSymbol)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](specializedQuantityKind.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](specializedQuantityKind.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](specializedQuantityKind.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](specializedQuantityKind.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "defaultscale": + var allowedVersionsForDefaultScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultScale"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "general": + var allowedVersionsForGeneral = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGeneral.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("general"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblescale": + var allowedVersionsForPossibleScale = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleScale"u8); + + if(value is IEnumerable objectListPossibleScale) + { + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "quantitydimensionsymbol": + var allowedVersionsForQuantityDimensionSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the SpecializedQuantityKind"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not SpecializedQuantityKind specializedQuantityKind) + { + throw new ArgumentException("The thing shall be a SpecializedQuantityKind", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of SpecializedQuantityKind since Version is below 1.0.0"); + return; } - var specializedQuantityKind = thing as SpecializedQuantityKind; - if (specializedQuantityKind == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a SpecializedQuantityKind."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(specializedQuantityKind.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(specializedQuantityKind.Actor.HasValue) + { + writer.WriteStringValue(specializedQuantityKind.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(specializedQuantityKind.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(specializedQuantityKind); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs index e03e6baab..336a62045 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using StakeHolderValueMap = CDP4Common.DTO.StakeHolderValueMap; /// /// The purpose of the class is to provide a specific serializer @@ -44,87 +50,849 @@ namespace CDP4JsonSerializer public class StakeHolderValueMapSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "goal", goal => new JArray(goal) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "requirement", requirement => new JArray(requirement) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "settings", settings => new JArray(settings) }, - { "shortName", shortName => new JValue(shortName) }, - { "stakeholderValue", stakeholderValue => new JArray(stakeholderValue) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueGroup", valueGroup => new JArray(valueGroup) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(StakeHolderValueMap stakeHolderValueMap) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](stakeHolderValueMap.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](stakeHolderValueMap.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), stakeHolderValueMap.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](stakeHolderValueMap.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("goal", this.PropertySerializerMap["goal"](stakeHolderValueMap.Goal.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](stakeHolderValueMap.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](stakeHolderValueMap.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](stakeHolderValueMap.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](stakeHolderValueMap.Name)); - jsonObject.Add("requirement", this.PropertySerializerMap["requirement"](stakeHolderValueMap.Requirement.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](stakeHolderValueMap.RevisionNumber)); - jsonObject.Add("settings", this.PropertySerializerMap["settings"](stakeHolderValueMap.Settings)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](stakeHolderValueMap.ShortName)); - jsonObject.Add("stakeholderValue", this.PropertySerializerMap["stakeholderValue"](stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](stakeHolderValueMap.ThingPreference)); - jsonObject.Add("valueGroup", this.PropertySerializerMap["valueGroup"](stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.guidComparer))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "goal": + var allowedVersionsForGoal = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGoal.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("goal"u8); + + if(value is IEnumerable objectListGoal) + { + foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "requirement": + var allowedVersionsForRequirement = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRequirement.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("requirement"u8); + + if(value is IEnumerable objectListRequirement) + { + foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "settings": + var allowedVersionsForSettings = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSettings.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("settings"u8); + + if(value is IEnumerable objectListSettings) + { + foreach(var settingsItem in objectListSettings.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(settingsItem); + } + } + + writer.WriteEndArray(); + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "stakeholdervalue": + var allowedVersionsForStakeholderValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("stakeholderValue"u8); + + if(value is IEnumerable objectListStakeholderValue) + { + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuegroup": + var allowedVersionsForValueGroup = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueGroup.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("valueGroup"u8); + + if(value is IEnumerable objectListValueGroup) + { + foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMap"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not StakeHolderValueMap stakeHolderValueMap) + { + throw new ArgumentException("The thing shall be a StakeHolderValueMap", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of StakeHolderValueMap since Version is below 1.1.0"); + return; } - var stakeHolderValueMap = thing as StakeHolderValueMap; - if (stakeHolderValueMap == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a StakeHolderValueMap."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeHolderValueMap.Name); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); + writer.WriteStartArray("settings"u8); + + foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(settingsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeHolderValueMap.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeHolderValueMap.Name); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); + writer.WriteStartArray("settings"u8); + + foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(settingsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeHolderValueMap.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMap.ThingPreference); + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeHolderValueMap.Actor.HasValue) + { + writer.WriteStringValue(stakeHolderValueMap.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeHolderValueMap.Name); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); + writer.WriteStartArray("settings"u8); + + foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(settingsItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeHolderValueMap.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMap.ThingPreference); + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(stakeHolderValueMap); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs index 9ac71efda..5d4612705 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using StakeHolderValueMapSettings = CDP4Common.DTO.StakeHolderValueMapSettings; /// /// The purpose of the class is to provide a specific serializer @@ -44,71 +50,520 @@ namespace CDP4JsonSerializer public class StakeHolderValueMapSettingsSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "goalToValueGroupRelationship", goalToValueGroupRelationship => new JValue(goalToValueGroupRelationship) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "stakeholderValueToRequirementRelationship", stakeholderValueToRequirementRelationship => new JValue(stakeholderValueToRequirementRelationship) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "valueGroupToStakeholderValueRelationship", valueGroupToStakeholderValueRelationship => new JValue(valueGroupToStakeholderValueRelationship) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(StakeHolderValueMapSettings stakeHolderValueMapSettings) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), stakeHolderValueMapSettings.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](stakeHolderValueMapSettings.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("goalToValueGroupRelationship", this.PropertySerializerMap["goalToValueGroupRelationship"](stakeHolderValueMapSettings.GoalToValueGroupRelationship)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](stakeHolderValueMapSettings.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](stakeHolderValueMapSettings.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](stakeHolderValueMapSettings.RevisionNumber)); - jsonObject.Add("stakeholderValueToRequirementRelationship", this.PropertySerializerMap["stakeholderValueToRequirementRelationship"](stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](stakeHolderValueMapSettings.ThingPreference)); - jsonObject.Add("valueGroupToStakeholderValueRelationship", this.PropertySerializerMap["valueGroupToStakeholderValueRelationship"](stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "goaltovaluegrouprelationship": + var allowedVersionsForGoalToValueGroupRelationship = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForGoalToValueGroupRelationship.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("goalToValueGroupRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "stakeholdervaluetorequirementrelationship": + var allowedVersionsForStakeholderValueToRequirementRelationship = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholderValueToRequirementRelationship.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuegrouptostakeholdervaluerelationship": + var allowedVersionsForValueGroupToStakeholderValueRelationship = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValueGroupToStakeholderValueRelationship.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMapSettings"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not StakeHolderValueMapSettings stakeHolderValueMapSettings) + { + throw new ArgumentException("The thing shall be a StakeHolderValueMapSettings", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of StakeHolderValueMapSettings since Version is below 1.1.0"); + return; } - var stakeHolderValueMapSettings = thing as StakeHolderValueMapSettings; - if (stakeHolderValueMapSettings == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a StakeHolderValueMapSettings."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMapSettings.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); + + if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.GoalToValueGroupRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMapSettings.RevisionNumber); + writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); + + if(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); + + if(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMapSettings.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); + + if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.GoalToValueGroupRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMapSettings.RevisionNumber); + writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); + + if(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ThingPreference); + writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); + + if(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeHolderValueMapSettings.Actor.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeHolderValueMapSettings.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); + + if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.GoalToValueGroupRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMapSettings.RevisionNumber); + writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); + + if(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.StakeholderValueToRequirementRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMapSettings.ThingPreference); + writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); + + if(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.HasValue) + { + writer.WriteStringValue(stakeHolderValueMapSettings.ValueGroupToStakeholderValueRelationship.Value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(stakeHolderValueMapSettings); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs index 418a744e9..fcde18fc7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Stakeholder = CDP4Common.DTO.Stakeholder; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,653 @@ namespace CDP4JsonSerializer public class StakeholderSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "stakeholderValue", stakeholderValue => new JArray(stakeholderValue) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Stakeholder stakeholder) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](stakeholder.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](stakeholder.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), stakeholder.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](stakeholder.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](stakeholder.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](stakeholder.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](stakeholder.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](stakeholder.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](stakeholder.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](stakeholder.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](stakeholder.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](stakeholder.ShortName)); - jsonObject.Add("stakeholderValue", this.PropertySerializerMap["stakeholderValue"](stakeholder.StakeholderValue.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](stakeholder.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "stakeholdervalue": + var allowedVersionsForStakeholderValue = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("stakeholderValue"u8); + + if(value is IEnumerable objectListStakeholderValue) + { + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + } + + writer.WriteEndArray(); + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Stakeholder"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Stakeholder stakeholder) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a Stakeholder", nameof(thing)); } - var stakeholder = thing as Stakeholder; - if (stakeholder == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Stakeholder since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Stakeholder."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholder.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeholder.Actor.HasValue) + { + writer.WriteStringValue(stakeholder.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholder.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(stakeholder); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs index aeafd65c6..7a7afb846 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using StakeholderValue = CDP4Common.DTO.StakeholderValue; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,604 @@ namespace CDP4JsonSerializer public class StakeholderValueSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(StakeholderValue stakeholderValue) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](stakeholderValue.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](stakeholderValue.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), stakeholderValue.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](stakeholderValue.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](stakeholderValue.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](stakeholderValue.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](stakeholderValue.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](stakeholderValue.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](stakeholderValue.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](stakeholderValue.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](stakeholderValue.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](stakeholderValue.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](stakeholderValue.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeholderValue"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not StakeholderValue stakeholderValue) + { + throw new ArgumentException("The thing shall be a StakeholderValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of StakeholderValue since Version is below 1.1.0"); + return; } - var stakeholderValue = thing as StakeholderValue; - if (stakeholderValue == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a StakeholderValue."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholderValue.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeholderValue.Actor.HasValue) + { + writer.WriteStringValue(stakeholderValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholderValue.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(stakeholderValue); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs index 01d37ef4f..028bdf061 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using TelephoneNumber = CDP4Common.DTO.TelephoneNumber; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,450 @@ namespace CDP4JsonSerializer public class TelephoneNumberSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(value) }, - { "vcardType", vcardType => new JArray(vcardType) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(TelephoneNumber telephoneNumber) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), telephoneNumber.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](telephoneNumber.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](telephoneNumber.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](telephoneNumber.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](telephoneNumber.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](telephoneNumber.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](telephoneNumber.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](telephoneNumber.Value)); - jsonObject.Add("vcardType", this.PropertySerializerMap["vcardType"](telephoneNumber.VcardType.Select(e => Enum.GetName(typeof(CDP4Common.SiteDirectoryData.VcardTelephoneNumberKind), e)))); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("value"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "vcardtype": + var allowedVersionsForVcardType = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForVcardType.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("vcardType"u8); + + if(value is IEnumerable objectListVcardType) + { + foreach(var vcardTypeItem in objectListVcardType) + { + writer.WriteStringValue(((VcardTelephoneNumberKind)vcardTypeItem).ToString()); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the TelephoneNumber"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not TelephoneNumber telephoneNumber) + { + throw new ArgumentException("The thing shall be a TelephoneNumber", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of TelephoneNumber since Version is below 1.0.0"); + return; } - var telephoneNumber = thing as TelephoneNumber; - if (telephoneNumber == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a TelephoneNumber."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(telephoneNumber.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(telephoneNumber.Actor.HasValue) + { + writer.WriteStringValue(telephoneNumber.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(telephoneNumber.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(telephoneNumber); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs index 73c9a4eeb..14e1340b2 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using Term = CDP4Common.DTO.Term; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,634 @@ namespace CDP4JsonSerializer public class TermSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(Term term) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](term.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), term.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](term.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](term.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](term.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](term.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](term.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](term.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](term.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](term.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](term.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](term.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](term.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Term"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not Term term) + { + throw new ArgumentException("The thing shall be a Term", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of Term since Version is below 1.0.0"); + return; } - var term = thing as Term; - if (term == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a Term."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(term.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(term.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(term.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(term.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(term.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(term.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(term.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(term.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(term.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(term.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(term.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(term.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(term.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(term.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(term.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(term.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(term.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(term.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(term.Actor.HasValue) + { + writer.WriteStringValue(term.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(term.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(term.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(term.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(term.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(term.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(term.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(term.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(term); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs index c789489fe..9c1d07169 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using TextParameterType = CDP4Common.DTO.TextParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class TextParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(TextParameterType textParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](textParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](textParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), textParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](textParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](textParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](textParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](textParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](textParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](textParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](textParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](textParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](textParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](textParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](textParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](textParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the TextParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not TextParameterType textParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a TextParameterType", nameof(thing)); } - var textParameterType = thing as TextParameterType; - if (textParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of TextParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a TextParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(textParameterType.Actor.HasValue) + { + writer.WriteStringValue(textParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(textParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs index fd66640d1..168f24037 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using TextualNote = CDP4Common.DTO.TextualNote; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,581 @@ namespace CDP4JsonSerializer public class TextualNoteSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "content", content => new JValue(content) }, - { "createdOn", createdOn => new JValue(((DateTime)createdOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "languageCode", languageCode => new JValue(languageCode) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "owner", owner => new JValue(owner) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(TextualNote textualNote) - { - var jsonObject = new JObject(); - jsonObject.Add("category", this.PropertySerializerMap["category"](textualNote.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), textualNote.ClassKind))); - jsonObject.Add("content", this.PropertySerializerMap["content"](textualNote.Content)); - jsonObject.Add("createdOn", this.PropertySerializerMap["createdOn"](textualNote.CreatedOn)); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](textualNote.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](textualNote.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](textualNote.Iid)); - jsonObject.Add("languageCode", this.PropertySerializerMap["languageCode"](textualNote.LanguageCode)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](textualNote.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](textualNote.Name)); - jsonObject.Add("owner", this.PropertySerializerMap["owner"](textualNote.Owner)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](textualNote.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](textualNote.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](textualNote.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + var allowedVersionsForContent = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForContent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "createdon": + var allowedVersionsForCreatedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + var allowedVersionsForLanguageCode = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + var allowedVersionsForOwner = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForOwner.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the TextualNote"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not TextualNote textualNote) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a TextualNote", nameof(thing)); } - var textualNote = thing as TextualNote; - if (textualNote == null) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new InvalidOperationException("The thing is not a TextualNote."); + Logger.Log(LogLevel.Info, "Skipping serialization of TextualNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textualNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(textualNote.Actor.HasValue) + { + writer.WriteStringValue(textualNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textualNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(textualNote); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs index bacae9364..a2f051dc4 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using TimeOfDayParameterType = CDP4Common.DTO.TimeOfDayParameterType; /// /// The purpose of the class is to provide a specific serializer @@ -44,81 +50,726 @@ namespace CDP4JsonSerializer public class TimeOfDayParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "symbol", symbol => new JValue(symbol) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(TimeOfDayParameterType timeOfDayParameterType) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](timeOfDayParameterType.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](timeOfDayParameterType.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), timeOfDayParameterType.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](timeOfDayParameterType.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](timeOfDayParameterType.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](timeOfDayParameterType.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](timeOfDayParameterType.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](timeOfDayParameterType.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](timeOfDayParameterType.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](timeOfDayParameterType.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](timeOfDayParameterType.ShortName)); - jsonObject.Add("symbol", this.PropertySerializerMap["symbol"](timeOfDayParameterType.Symbol)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](timeOfDayParameterType.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "symbol": + var allowedVersionsForSymbol = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForSymbol.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the TimeOfDayParameterType"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not TimeOfDayParameterType timeOfDayParameterType) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a TimeOfDayParameterType", nameof(thing)); } - var timeOfDayParameterType = thing as TimeOfDayParameterType; - if (timeOfDayParameterType == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of TimeOfDayParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a TimeOfDayParameterType."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(timeOfDayParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(timeOfDayParameterType.Actor.HasValue) + { + writer.WriteStringValue(timeOfDayParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(timeOfDayParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(timeOfDayParameterType); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs index 269622ccd..5e5c72687 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using UnitFactor = CDP4Common.DTO.UnitFactor; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class UnitFactorSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "exponent", exponent => new JValue(exponent) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "unit", unit => new JValue(unit) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(UnitFactor unitFactor) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), unitFactor.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](unitFactor.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](unitFactor.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("exponent", this.PropertySerializerMap["exponent"](unitFactor.Exponent)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](unitFactor.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](unitFactor.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](unitFactor.RevisionNumber)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](unitFactor.ThingPreference)); - jsonObject.Add("unit", this.PropertySerializerMap["unit"](unitFactor.Unit)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "exponent": + var allowedVersionsForExponent = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExponent.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("exponent"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "unit": + var allowedVersionsForUnit = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForUnit.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("unit"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the UnitFactor"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not UnitFactor unitFactor) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a UnitFactor", nameof(thing)); } - var unitFactor = thing as UnitFactor; - if (unitFactor == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UnitFactor since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a UnitFactor."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitFactor.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(unitFactor.Actor.HasValue) + { + writer.WriteStringValue(unitFactor.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitFactor.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(unitFactor); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs index 9d93d94d0..dfbf4c97d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using UnitPrefix = CDP4Common.DTO.UnitPrefix; /// /// The purpose of the class is to provide a specific serializer @@ -44,79 +50,668 @@ namespace CDP4JsonSerializer public class UnitPrefixSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "conversionFactor", conversionFactor => new JValue(conversionFactor) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "isDeprecated", isDeprecated => new JValue(isDeprecated) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(UnitPrefix unitPrefix) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](unitPrefix.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), unitPrefix.ClassKind))); - jsonObject.Add("conversionFactor", this.PropertySerializerMap["conversionFactor"](unitPrefix.ConversionFactor)); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](unitPrefix.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](unitPrefix.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](unitPrefix.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](unitPrefix.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](unitPrefix.Iid)); - jsonObject.Add("isDeprecated", this.PropertySerializerMap["isDeprecated"](unitPrefix.IsDeprecated)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](unitPrefix.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](unitPrefix.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](unitPrefix.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](unitPrefix.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](unitPrefix.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "conversionfactor": + var allowedVersionsForConversionFactor = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForConversionFactor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("conversionFactor"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + var allowedVersionsForIsDeprecated = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the UnitPrefix"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not UnitPrefix unitPrefix) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a UnitPrefix", nameof(thing)); } - var unitPrefix = thing as UnitPrefix; - if (unitPrefix == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - throw new InvalidOperationException("The thing is not a UnitPrefix."); + Logger.Log(LogLevel.Info, "Skipping serialization of UnitPrefix since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitPrefix.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(unitPrefix.Actor.HasValue) + { + writer.WriteStringValue(unitPrefix.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitPrefix.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(unitPrefix); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs index a17a3a926..2e84713ae 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using UserPreference = CDP4Common.DTO.UserPreference; /// /// The purpose of the class is to provide a specific serializer @@ -44,69 +50,426 @@ namespace CDP4JsonSerializer public class UserPreferenceSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "value", value => new JValue(value) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(UserPreference userPreference) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), userPreference.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](userPreference.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](userPreference.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](userPreference.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](userPreference.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](userPreference.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](userPreference.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](userPreference.ThingPreference)); - jsonObject.Add("value", this.PropertySerializerMap["value"](userPreference.Value)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + var allowedVersionsForValue = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForValue.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("value"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the UserPreference"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not UserPreference userPreference) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a UserPreference", nameof(thing)); } - var userPreference = thing as UserPreference; - if (userPreference == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UserPreference since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a UserPreference."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userPreference.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(userPreference.Actor.HasValue) + { + writer.WriteStringValue(userPreference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userPreference.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(userPreference); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs index e1a4946c4..2341cbf1f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using UserRuleVerification = CDP4Common.DTO.UserRuleVerification; /// /// The purpose of the class is to provide a specific serializer @@ -44,74 +50,588 @@ namespace CDP4JsonSerializer public class UserRuleVerificationSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "executedOn", executedOn => new JValue(executedOn != null ? ((DateTime)executedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ") : null) }, - { "iid", iid => new JValue(iid) }, - { "isActive", isActive => new JValue(isActive) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "rule", rule => new JValue(rule) }, - { "status", status => new JValue(status.ToString()) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - { "violation", violation => new JArray(violation) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(UserRuleVerification userRuleVerification) - { - var jsonObject = new JObject(); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), userRuleVerification.ClassKind))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](userRuleVerification.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](userRuleVerification.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("executedOn", this.PropertySerializerMap["executedOn"](userRuleVerification.ExecutedOn)); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](userRuleVerification.Iid)); - jsonObject.Add("isActive", this.PropertySerializerMap["isActive"](userRuleVerification.IsActive)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](userRuleVerification.ModifiedOn)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](userRuleVerification.RevisionNumber)); - jsonObject.Add("rule", this.PropertySerializerMap["rule"](userRuleVerification.Rule)); - jsonObject.Add("status", this.PropertySerializerMap["status"](Enum.GetName(typeof(CDP4Common.EngineeringModelData.RuleVerificationStatusKind), userRuleVerification.Status))); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](userRuleVerification.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "executedon": + var allowedVersionsForExecutedOn = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExecutedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("executedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isactive": + var allowedVersionsForIsActive = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIsActive.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isActive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "rule": + var allowedVersionsForRule = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRule.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("rule"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "status": + var allowedVersionsForStatus = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForStatus.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("status"u8); + + if(value != null) + { + writer.WriteStringValue(((RuleVerificationStatusKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "violation": + var allowedVersionsForViolation = new List + { + "1.0.0", + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForViolation.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("violation"u8); + + if(value is IEnumerable objectListViolation) + { + foreach(var violationItem in objectListViolation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + } + + writer.WriteEndArray(); + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the UserRuleVerification"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not UserRuleVerification userRuleVerification) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + throw new ArgumentException("The thing shall be a UserRuleVerification", nameof(thing)); } - var userRuleVerification = thing as UserRuleVerification; - if (userRuleVerification == null) + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UserRuleVerification since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a UserRuleVerification."); + case "1.0.0": + Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(userRuleVerification.Actor.HasValue) + { + writer.WriteStringValue(userRuleVerification.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(userRuleVerification); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs index a1853c804..81d529ef1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2022 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// This is an auto-generated class. Any manual changes to this file will be overwritten! -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -------------------------------------------------------------------------------------------------------------------- +// +// ------------------------------------------------------------------------------------------------------------------------------- // ------------------------------------------------------------------------------------------------ // --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- @@ -29,14 +29,20 @@ namespace CDP4JsonSerializer { using System; - using System.Collections; using System.Collections.Generic; using System.Linq; + using System.Text.Json; - using CDP4Common.DTO; + using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; + using CDP4Common.ReportingData; + using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using Newtonsoft.Json.Linq; + using NLog; + + using Thing = CDP4Common.DTO.Thing; + using ValueGroup = CDP4Common.DTO.ValueGroup; /// /// The purpose of the class is to provide a specific serializer @@ -44,77 +50,604 @@ namespace CDP4JsonSerializer public class ValueGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// The map containing the serialization methods + /// Serialize a value for a property into a /// - private readonly Dictionary> propertySerializerMap = new Dictionary> + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { - { "actor", actor => new JValue(actor) }, - { "alias", alias => new JArray(alias) }, - { "category", category => new JArray(category) }, - { "classKind", classKind => new JValue(classKind.ToString()) }, - { "definition", definition => new JArray(definition) }, - { "excludedDomain", excludedDomain => new JArray(excludedDomain) }, - { "excludedPerson", excludedPerson => new JArray(excludedPerson) }, - { "hyperLink", hyperLink => new JArray(hyperLink) }, - { "iid", iid => new JValue(iid) }, - { "modifiedOn", modifiedOn => new JValue(((DateTime)modifiedOn).ToString("yyyy-MM-ddTHH:mm:ss.fffZ")) }, - { "name", name => new JValue(name) }, - { "revisionNumber", revisionNumber => new JValue(revisionNumber) }, - { "shortName", shortName => new JValue(shortName) }, - { "thingPreference", thingPreference => new JValue(thingPreference) }, - }; + var requestedVersion = requestedDataModelVersion.ToString(3); - /// - /// Serialize the - /// - /// The to serialize - /// The - private JObject Serialize(ValueGroup valueGroup) - { - var jsonObject = new JObject(); - jsonObject.Add("alias", this.PropertySerializerMap["alias"](valueGroup.Alias.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("category", this.PropertySerializerMap["category"](valueGroup.Category.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("classKind", this.PropertySerializerMap["classKind"](Enum.GetName(typeof(CDP4Common.CommonData.ClassKind), valueGroup.ClassKind))); - jsonObject.Add("definition", this.PropertySerializerMap["definition"](valueGroup.Definition.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedDomain", this.PropertySerializerMap["excludedDomain"](valueGroup.ExcludedDomain.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("excludedPerson", this.PropertySerializerMap["excludedPerson"](valueGroup.ExcludedPerson.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("hyperLink", this.PropertySerializerMap["hyperLink"](valueGroup.HyperLink.OrderBy(x => x, this.guidComparer))); - jsonObject.Add("iid", this.PropertySerializerMap["iid"](valueGroup.Iid)); - jsonObject.Add("modifiedOn", this.PropertySerializerMap["modifiedOn"](valueGroup.ModifiedOn)); - jsonObject.Add("name", this.PropertySerializerMap["name"](valueGroup.Name)); - jsonObject.Add("revisionNumber", this.PropertySerializerMap["revisionNumber"](valueGroup.RevisionNumber)); - jsonObject.Add("shortName", this.PropertySerializerMap["shortName"](valueGroup.ShortName)); - jsonObject.Add("thingPreference", this.PropertySerializerMap["thingPreference"](valueGroup.ThingPreference)); - return jsonObject; - } + switch(propertyName.ToLower()) + { + case "actor": + var allowedVersionsForActor = new List + { + "1.3.0", + }; - /// - /// Gets the map containing the serialization method for each property of the class. - /// - public IReadOnlyDictionary> PropertySerializerMap - { - get { return this.propertySerializerMap; } + if(!allowedVersionsForActor.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + var allowedVersionsForAlias = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForAlias.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + var allowedVersionsForCategory = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForCategory.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + var allowedVersionsForClassKind = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForClassKind.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + var allowedVersionsForDefinition = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForDefinition.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + var allowedVersionsForExcludedDomain = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + var allowedVersionsForExcludedPerson = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + var allowedVersionsForHyperLink = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + var allowedVersionsForIid = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForIid.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + var allowedVersionsForModifiedOn = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + var allowedVersionsForName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + var allowedVersionsForRevisionNumber = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + var allowedVersionsForShortName = new List + { + "1.1.0", + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForShortName.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + var allowedVersionsForThingPreference = new List + { + "1.2.0", + "1.3.0", + }; + + if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ValueGroup"); + } } /// - /// Serialize the to JObject + /// Serializes a into an /// - /// The to serialize - /// The - public JObject Serialize(Thing thing) + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - if (thing == null) + if (thing is not ValueGroup valueGroup) + { + throw new ArgumentException("The thing shall be a ValueGroup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - throw new ArgumentNullException($"The {nameof(thing)} may not be null.", nameof(thing)); + Logger.Log(LogLevel.Info, "Skipping serialization of ValueGroup since Version is below 1.1.0"); + return; } - var valueGroup = thing as ValueGroup; - if (valueGroup == null) + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) { - throw new InvalidOperationException("The thing is not a ValueGroup."); + case "1.1.0": + Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(valueGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(valueGroup.Actor.HasValue) + { + writer.WriteStringValue(valueGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(valueGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); } - return this.Serialize(valueGroup); + writer.WriteEndObject(); } } } diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/ActualFiniteStateKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/ActualFiniteStateKindDeserializer.cs new file mode 100644 index 000000000..f1d450c52 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/ActualFiniteStateKindDeserializer.cs @@ -0,0 +1,64 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class ActualFiniteStateKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static ActualFiniteStateKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "MANDATORY" => ActualFiniteStateKind.MANDATORY, + "FORBIDDEN" => ActualFiniteStateKind.FORBIDDEN, + _ => throw new InvalidDataException($"{value} is not a valid for ActualFiniteStateKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationApprovalKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationApprovalKindDeserializer.cs new file mode 100644 index 000000000..4102f47fd --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationApprovalKindDeserializer.cs @@ -0,0 +1,65 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.ReportingData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class AnnotationApprovalKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static AnnotationApprovalKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "ACCEPTED" => AnnotationApprovalKind.ACCEPTED, + "REJECTED" => AnnotationApprovalKind.REJECTED, + "WITHDRAWN" => AnnotationApprovalKind.WITHDRAWN, + _ => throw new InvalidDataException($"{value} is not a valid for AnnotationApprovalKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationClassificationKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationClassificationKindDeserializer.cs new file mode 100644 index 000000000..d9ae34f96 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationClassificationKindDeserializer.cs @@ -0,0 +1,64 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.ReportingData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class AnnotationClassificationKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static AnnotationClassificationKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "MAJOR" => AnnotationClassificationKind.MAJOR, + "MINOR" => AnnotationClassificationKind.MINOR, + _ => throw new InvalidDataException($"{value} is not a valid for AnnotationClassificationKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationStatusKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationStatusKindDeserializer.cs new file mode 100644 index 000000000..2448faab9 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/AnnotationStatusKindDeserializer.cs @@ -0,0 +1,68 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.ReportingData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class AnnotationStatusKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static AnnotationStatusKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "OPEN" => AnnotationStatusKind.OPEN, + "DONE" => AnnotationStatusKind.DONE, + "CLOSED" => AnnotationStatusKind.CLOSED, + "INVALID" => AnnotationStatusKind.INVALID, + "WONTFIX" => AnnotationStatusKind.WONTFIX, + "NOT_APPLICABLE" => AnnotationStatusKind.NOT_APPLICABLE, + _ => throw new InvalidDataException($"{value} is not a valid for AnnotationStatusKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/BooleanOperatorKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/BooleanOperatorKindDeserializer.cs new file mode 100644 index 000000000..850f139b5 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/BooleanOperatorKindDeserializer.cs @@ -0,0 +1,65 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class BooleanOperatorKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static BooleanOperatorKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "AND" => BooleanOperatorKind.AND, + "OR" => BooleanOperatorKind.OR, + "XOR" => BooleanOperatorKind.XOR, + _ => throw new InvalidDataException($"{value} is not a valid for BooleanOperatorKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/ClassKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/ClassKindDeserializer.cs new file mode 100644 index 000000000..cca7ec8a5 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/ClassKindDeserializer.cs @@ -0,0 +1,243 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.CommonData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class ClassKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static ClassKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "ActionItem" => ClassKind.ActionItem, + "ActualFiniteState" => ClassKind.ActualFiniteState, + "ActualFiniteStateList" => ClassKind.ActualFiniteStateList, + "Alias" => ClassKind.Alias, + "AndExpression" => ClassKind.AndExpression, + "Approval" => ClassKind.Approval, + "ArrayParameterType" => ClassKind.ArrayParameterType, + "BinaryNote" => ClassKind.BinaryNote, + "BinaryRelationship" => ClassKind.BinaryRelationship, + "BinaryRelationshipRule" => ClassKind.BinaryRelationshipRule, + "Book" => ClassKind.Book, + "BooleanExpression" => ClassKind.BooleanExpression, + "BooleanParameterType" => ClassKind.BooleanParameterType, + "Bounds" => ClassKind.Bounds, + "BuiltInRuleVerification" => ClassKind.BuiltInRuleVerification, + "Category" => ClassKind.Category, + "ChangeProposal" => ClassKind.ChangeProposal, + "ChangeRequest" => ClassKind.ChangeRequest, + "Citation" => ClassKind.Citation, + "Color" => ClassKind.Color, + "CommonFileStore" => ClassKind.CommonFileStore, + "CompoundParameterType" => ClassKind.CompoundParameterType, + "Constant" => ClassKind.Constant, + "ContractChangeNotice" => ClassKind.ContractChangeNotice, + "ContractDeviation" => ClassKind.ContractDeviation, + "ConversionBasedUnit" => ClassKind.ConversionBasedUnit, + "CyclicRatioScale" => ClassKind.CyclicRatioScale, + "DateParameterType" => ClassKind.DateParameterType, + "DateTimeParameterType" => ClassKind.DateTimeParameterType, + "DecompositionRule" => ClassKind.DecompositionRule, + "DefinedThing" => ClassKind.DefinedThing, + "Definition" => ClassKind.Definition, + "DependentParameterTypeAssignment" => ClassKind.DependentParameterTypeAssignment, + "DerivedQuantityKind" => ClassKind.DerivedQuantityKind, + "DerivedUnit" => ClassKind.DerivedUnit, + "DiagramCanvas" => ClassKind.DiagramCanvas, + "DiagramEdge" => ClassKind.DiagramEdge, + "DiagramElementContainer" => ClassKind.DiagramElementContainer, + "DiagramElementThing" => ClassKind.DiagramElementThing, + "DiagrammingStyle" => ClassKind.DiagrammingStyle, + "DiagramObject" => ClassKind.DiagramObject, + "DiagramShape" => ClassKind.DiagramShape, + "DiagramThingBase" => ClassKind.DiagramThingBase, + "DiscussionItem" => ClassKind.DiscussionItem, + "DomainFileStore" => ClassKind.DomainFileStore, + "DomainOfExpertise" => ClassKind.DomainOfExpertise, + "DomainOfExpertiseGroup" => ClassKind.DomainOfExpertiseGroup, + "ElementBase" => ClassKind.ElementBase, + "ElementDefinition" => ClassKind.ElementDefinition, + "ElementUsage" => ClassKind.ElementUsage, + "EmailAddress" => ClassKind.EmailAddress, + "EngineeringModel" => ClassKind.EngineeringModel, + "EngineeringModelDataAnnotation" => ClassKind.EngineeringModelDataAnnotation, + "EngineeringModelDataDiscussionItem" => ClassKind.EngineeringModelDataDiscussionItem, + "EngineeringModelDataNote" => ClassKind.EngineeringModelDataNote, + "EngineeringModelSetup" => ClassKind.EngineeringModelSetup, + "EnumerationParameterType" => ClassKind.EnumerationParameterType, + "EnumerationValueDefinition" => ClassKind.EnumerationValueDefinition, + "ExclusiveOrExpression" => ClassKind.ExclusiveOrExpression, + "ExternalIdentifierMap" => ClassKind.ExternalIdentifierMap, + "File" => ClassKind.File, + "FileRevision" => ClassKind.FileRevision, + "FileStore" => ClassKind.FileStore, + "FileType" => ClassKind.FileType, + "Folder" => ClassKind.Folder, + "GenericAnnotation" => ClassKind.GenericAnnotation, + "Glossary" => ClassKind.Glossary, + "Goal" => ClassKind.Goal, + "HyperLink" => ClassKind.HyperLink, + "IdCorrespondence" => ClassKind.IdCorrespondence, + "IndependentParameterTypeAssignment" => ClassKind.IndependentParameterTypeAssignment, + "IntervalScale" => ClassKind.IntervalScale, + "Iteration" => ClassKind.Iteration, + "IterationSetup" => ClassKind.IterationSetup, + "LinearConversionUnit" => ClassKind.LinearConversionUnit, + "LogarithmicScale" => ClassKind.LogarithmicScale, + "LogEntryChangelogItem" => ClassKind.LogEntryChangelogItem, + "MappingToReferenceScale" => ClassKind.MappingToReferenceScale, + "MeasurementScale" => ClassKind.MeasurementScale, + "MeasurementUnit" => ClassKind.MeasurementUnit, + "ModellingAnnotationItem" => ClassKind.ModellingAnnotationItem, + "ModellingThingReference" => ClassKind.ModellingThingReference, + "ModelLogEntry" => ClassKind.ModelLogEntry, + "ModelReferenceDataLibrary" => ClassKind.ModelReferenceDataLibrary, + "MultiRelationship" => ClassKind.MultiRelationship, + "MultiRelationshipRule" => ClassKind.MultiRelationshipRule, + "NaturalLanguage" => ClassKind.NaturalLanguage, + "NestedElement" => ClassKind.NestedElement, + "NestedParameter" => ClassKind.NestedParameter, + "Note" => ClassKind.Note, + "NotExpression" => ClassKind.NotExpression, + "NotThing" => ClassKind.NotThing, + "Option" => ClassKind.Option, + "OrdinalScale" => ClassKind.OrdinalScale, + "OrExpression" => ClassKind.OrExpression, + "Organization" => ClassKind.Organization, + "OrganizationalParticipant" => ClassKind.OrganizationalParticipant, + "OwnedStyle" => ClassKind.OwnedStyle, + "Page" => ClassKind.Page, + "Parameter" => ClassKind.Parameter, + "ParameterBase" => ClassKind.ParameterBase, + "ParameterGroup" => ClassKind.ParameterGroup, + "ParameterizedCategoryRule" => ClassKind.ParameterizedCategoryRule, + "ParameterOrOverrideBase" => ClassKind.ParameterOrOverrideBase, + "ParameterOverride" => ClassKind.ParameterOverride, + "ParameterOverrideValueSet" => ClassKind.ParameterOverrideValueSet, + "ParameterSubscription" => ClassKind.ParameterSubscription, + "ParameterSubscriptionValueSet" => ClassKind.ParameterSubscriptionValueSet, + "ParameterType" => ClassKind.ParameterType, + "ParameterTypeComponent" => ClassKind.ParameterTypeComponent, + "ParameterValue" => ClassKind.ParameterValue, + "ParameterValueSet" => ClassKind.ParameterValueSet, + "ParameterValueSetBase" => ClassKind.ParameterValueSetBase, + "ParametricConstraint" => ClassKind.ParametricConstraint, + "Participant" => ClassKind.Participant, + "ParticipantPermission" => ClassKind.ParticipantPermission, + "ParticipantRole" => ClassKind.ParticipantRole, + "Person" => ClassKind.Person, + "PersonPermission" => ClassKind.PersonPermission, + "PersonRole" => ClassKind.PersonRole, + "Point" => ClassKind.Point, + "PossibleFiniteState" => ClassKind.PossibleFiniteState, + "PossibleFiniteStateList" => ClassKind.PossibleFiniteStateList, + "PrefixedUnit" => ClassKind.PrefixedUnit, + "Publication" => ClassKind.Publication, + "QuantityKind" => ClassKind.QuantityKind, + "QuantityKindFactor" => ClassKind.QuantityKindFactor, + "RatioScale" => ClassKind.RatioScale, + "ReferenceDataLibrary" => ClassKind.ReferenceDataLibrary, + "ReferencerRule" => ClassKind.ReferencerRule, + "ReferenceSource" => ClassKind.ReferenceSource, + "RelationalExpression" => ClassKind.RelationalExpression, + "Relationship" => ClassKind.Relationship, + "RelationshipParameterValue" => ClassKind.RelationshipParameterValue, + "RequestForDeviation" => ClassKind.RequestForDeviation, + "RequestForWaiver" => ClassKind.RequestForWaiver, + "Requirement" => ClassKind.Requirement, + "RequirementsContainer" => ClassKind.RequirementsContainer, + "RequirementsContainerParameterValue" => ClassKind.RequirementsContainerParameterValue, + "RequirementsGroup" => ClassKind.RequirementsGroup, + "RequirementsSpecification" => ClassKind.RequirementsSpecification, + "ReviewItemDiscrepancy" => ClassKind.ReviewItemDiscrepancy, + "Rule" => ClassKind.Rule, + "RuleVerification" => ClassKind.RuleVerification, + "RuleVerificationList" => ClassKind.RuleVerificationList, + "RuleViolation" => ClassKind.RuleViolation, + "SampledFunctionParameterType" => ClassKind.SampledFunctionParameterType, + "ScalarParameterType" => ClassKind.ScalarParameterType, + "ScaleReferenceQuantityValue" => ClassKind.ScaleReferenceQuantityValue, + "ScaleValueDefinition" => ClassKind.ScaleValueDefinition, + "Section" => ClassKind.Section, + "SharedStyle" => ClassKind.SharedStyle, + "SimpleParameterizableThing" => ClassKind.SimpleParameterizableThing, + "SimpleParameterValue" => ClassKind.SimpleParameterValue, + "SimpleQuantityKind" => ClassKind.SimpleQuantityKind, + "SimpleUnit" => ClassKind.SimpleUnit, + "SiteDirectory" => ClassKind.SiteDirectory, + "SiteDirectoryDataAnnotation" => ClassKind.SiteDirectoryDataAnnotation, + "SiteDirectoryDataDiscussionItem" => ClassKind.SiteDirectoryDataDiscussionItem, + "SiteDirectoryThingReference" => ClassKind.SiteDirectoryThingReference, + "SiteLogEntry" => ClassKind.SiteLogEntry, + "SiteReferenceDataLibrary" => ClassKind.SiteReferenceDataLibrary, + "Solution" => ClassKind.Solution, + "SpecializedQuantityKind" => ClassKind.SpecializedQuantityKind, + "Stakeholder" => ClassKind.Stakeholder, + "StakeholderValue" => ClassKind.StakeholderValue, + "StakeHolderValueMap" => ClassKind.StakeHolderValueMap, + "StakeHolderValueMapSettings" => ClassKind.StakeHolderValueMapSettings, + "TelephoneNumber" => ClassKind.TelephoneNumber, + "Term" => ClassKind.Term, + "TextParameterType" => ClassKind.TextParameterType, + "TextualNote" => ClassKind.TextualNote, + "Thing" => ClassKind.Thing, + "ThingReference" => ClassKind.ThingReference, + "TimeOfDayParameterType" => ClassKind.TimeOfDayParameterType, + "TopContainer" => ClassKind.TopContainer, + "UnitFactor" => ClassKind.UnitFactor, + "UnitPrefix" => ClassKind.UnitPrefix, + "UserPreference" => ClassKind.UserPreference, + "UserRuleVerification" => ClassKind.UserRuleVerification, + "ValueGroup" => ClassKind.ValueGroup, + _ => throw new InvalidDataException($"{value} is not a valid for ClassKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/EngineeringModelKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/EngineeringModelKindDeserializer.cs new file mode 100644 index 000000000..d0990d71e --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/EngineeringModelKindDeserializer.cs @@ -0,0 +1,66 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class EngineeringModelKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static EngineeringModelKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "STUDY_MODEL" => EngineeringModelKind.STUDY_MODEL, + "TEMPLATE_MODEL" => EngineeringModelKind.TEMPLATE_MODEL, + "MODEL_CATALOGUE" => EngineeringModelKind.MODEL_CATALOGUE, + "SCRATCH_MODEL" => EngineeringModelKind.SCRATCH_MODEL, + _ => throw new InvalidDataException($"{value} is not a valid for EngineeringModelKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/InterfaceEndKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/InterfaceEndKindDeserializer.cs new file mode 100644 index 000000000..f8d5372d9 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/InterfaceEndKindDeserializer.cs @@ -0,0 +1,67 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class InterfaceEndKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static InterfaceEndKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NONE" => InterfaceEndKind.NONE, + "UNDIRECTED" => InterfaceEndKind.UNDIRECTED, + "INPUT" => InterfaceEndKind.INPUT, + "OUTPUT" => InterfaceEndKind.OUTPUT, + "IN_OUT" => InterfaceEndKind.IN_OUT, + _ => throw new InvalidDataException($"{value} is not a valid for InterfaceEndKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/LogEntryChangelogItemKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogEntryChangelogItemKindDeserializer.cs new file mode 100644 index 000000000..a5be3bc32 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogEntryChangelogItemKindDeserializer.cs @@ -0,0 +1,65 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.CommonData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class LogEntryChangelogItemKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static LogEntryChangelogItemKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "ADD" => LogEntryChangelogItemKind.ADD, + "UPDATE" => LogEntryChangelogItemKind.UPDATE, + "DELETE" => LogEntryChangelogItemKind.DELETE, + _ => throw new InvalidDataException($"{value} is not a valid for LogEntryChangelogItemKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/LogLevelKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogLevelKindDeserializer.cs new file mode 100644 index 000000000..96f9c0dbe --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogLevelKindDeserializer.cs @@ -0,0 +1,66 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.CommonData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class LogLevelKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static LogLevelKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "TRACE" => LogLevelKind.TRACE, + "DEBUG" => LogLevelKind.DEBUG, + "INFO" => LogLevelKind.INFO, + "USER" => LogLevelKind.USER, + _ => throw new InvalidDataException($"{value} is not a valid for LogLevelKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/LogarithmBaseKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogarithmBaseKindDeserializer.cs new file mode 100644 index 000000000..5f132393b --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/LogarithmBaseKindDeserializer.cs @@ -0,0 +1,65 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class LogarithmBaseKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static LogarithmBaseKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NATURAL" => LogarithmBaseKind.NATURAL, + "BASE2" => LogarithmBaseKind.BASE2, + "BASE10" => LogarithmBaseKind.BASE10, + _ => throw new InvalidDataException($"{value} is not a valid for LogarithmBaseKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/NumberSetKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/NumberSetKindDeserializer.cs new file mode 100644 index 000000000..c2305d32f --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/NumberSetKindDeserializer.cs @@ -0,0 +1,66 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class NumberSetKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static NumberSetKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NATURAL_NUMBER_SET" => NumberSetKind.NATURAL_NUMBER_SET, + "INTEGER_NUMBER_SET" => NumberSetKind.INTEGER_NUMBER_SET, + "RATIONAL_NUMBER_SET" => NumberSetKind.RATIONAL_NUMBER_SET, + "REAL_NUMBER_SET" => NumberSetKind.REAL_NUMBER_SET, + _ => throw new InvalidDataException($"{value} is not a valid for NumberSetKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/ParameterSwitchKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/ParameterSwitchKindDeserializer.cs new file mode 100644 index 000000000..1dc6fcd34 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/ParameterSwitchKindDeserializer.cs @@ -0,0 +1,65 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class ParameterSwitchKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static ParameterSwitchKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "COMPUTED" => ParameterSwitchKind.COMPUTED, + "MANUAL" => ParameterSwitchKind.MANUAL, + "REFERENCE" => ParameterSwitchKind.REFERENCE, + _ => throw new InvalidDataException($"{value} is not a valid for ParameterSwitchKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/ParticipantAccessRightKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/ParticipantAccessRightKindDeserializer.cs new file mode 100644 index 000000000..451150651 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/ParticipantAccessRightKindDeserializer.cs @@ -0,0 +1,69 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.CommonData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class ParticipantAccessRightKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static ParticipantAccessRightKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NOT_APPLICABLE" => ParticipantAccessRightKind.NOT_APPLICABLE, + "NONE" => ParticipantAccessRightKind.NONE, + "SAME_AS_CONTAINER" => ParticipantAccessRightKind.SAME_AS_CONTAINER, + "SAME_AS_SUPERCLASS" => ParticipantAccessRightKind.SAME_AS_SUPERCLASS, + "READ" => ParticipantAccessRightKind.READ, + "MODIFY" => ParticipantAccessRightKind.MODIFY, + "MODIFY_IF_OWNER" => ParticipantAccessRightKind.MODIFY_IF_OWNER, + _ => throw new InvalidDataException($"{value} is not a valid for ParticipantAccessRightKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/PersonAccessRightKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/PersonAccessRightKindDeserializer.cs new file mode 100644 index 000000000..331bbf18c --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/PersonAccessRightKindDeserializer.cs @@ -0,0 +1,71 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.CommonData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class PersonAccessRightKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static PersonAccessRightKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NOT_APPLICABLE" => PersonAccessRightKind.NOT_APPLICABLE, + "NONE" => PersonAccessRightKind.NONE, + "SAME_AS_CONTAINER" => PersonAccessRightKind.SAME_AS_CONTAINER, + "SAME_AS_SUPERCLASS" => PersonAccessRightKind.SAME_AS_SUPERCLASS, + "READ" => PersonAccessRightKind.READ, + "MODIFY" => PersonAccessRightKind.MODIFY, + "READ_IF_PARTICIPANT" => PersonAccessRightKind.READ_IF_PARTICIPANT, + "MODIFY_IF_PARTICIPANT" => PersonAccessRightKind.MODIFY_IF_PARTICIPANT, + "MODIFY_OWN_PERSON" => PersonAccessRightKind.MODIFY_OWN_PERSON, + _ => throw new InvalidDataException($"{value} is not a valid for PersonAccessRightKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/RelationalOperatorKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/RelationalOperatorKindDeserializer.cs new file mode 100644 index 000000000..5cdf396be --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/RelationalOperatorKindDeserializer.cs @@ -0,0 +1,68 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class RelationalOperatorKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static RelationalOperatorKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "EQ" => RelationalOperatorKind.EQ, + "NE" => RelationalOperatorKind.NE, + "LT" => RelationalOperatorKind.LT, + "GT" => RelationalOperatorKind.GT, + "LE" => RelationalOperatorKind.LE, + "GE" => RelationalOperatorKind.GE, + _ => throw new InvalidDataException($"{value} is not a valid for RelationalOperatorKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/RuleVerificationStatusKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/RuleVerificationStatusKindDeserializer.cs new file mode 100644 index 000000000..9f73e8c37 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/RuleVerificationStatusKindDeserializer.cs @@ -0,0 +1,66 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.EngineeringModelData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class RuleVerificationStatusKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static RuleVerificationStatusKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "NONE" => RuleVerificationStatusKind.NONE, + "PASSED" => RuleVerificationStatusKind.PASSED, + "FAILED" => RuleVerificationStatusKind.FAILED, + "INCONCLUSIVE" => RuleVerificationStatusKind.INCONCLUSIVE, + _ => throw new InvalidDataException($"{value} is not a valid for RuleVerificationStatusKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/StudyPhaseKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/StudyPhaseKindDeserializer.cs new file mode 100644 index 000000000..0bbad8cc7 --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/StudyPhaseKindDeserializer.cs @@ -0,0 +1,66 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class StudyPhaseKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static StudyPhaseKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "PREPARATION_PHASE" => StudyPhaseKind.PREPARATION_PHASE, + "DESIGN_SESSION_PHASE" => StudyPhaseKind.DESIGN_SESSION_PHASE, + "REPORTING_PHASE" => StudyPhaseKind.REPORTING_PHASE, + "COMPLETED_STUDY" => StudyPhaseKind.COMPLETED_STUDY, + _ => throw new InvalidDataException($"{value} is not a valid for StudyPhaseKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardEmailAddressKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardEmailAddressKindDeserializer.cs new file mode 100644 index 000000000..4fb8c099d --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardEmailAddressKindDeserializer.cs @@ -0,0 +1,64 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class VcardEmailAddressKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static VcardEmailAddressKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "WORK" => VcardEmailAddressKind.WORK, + "HOME" => VcardEmailAddressKind.HOME, + _ => throw new InvalidDataException($"{value} is not a valid for VcardEmailAddressKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardTelephoneNumberKindDeserializer.cs b/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardTelephoneNumberKindDeserializer.cs new file mode 100644 index 000000000..9048d9c7d --- /dev/null +++ b/CDP4JsonSerializer/AutoGenEnumDeserializers/VcardTelephoneNumberKindDeserializer.cs @@ -0,0 +1,71 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ + +namespace CDP4JsonSerializer +{ + using System; + using System.IO; + using System.Text.Json; + + using CDP4Common.SiteDirectoryData; + + /// + /// The purpose of the is to deserialize a JSON object to a + /// + internal static class VcardTelephoneNumberKindDeserializer + { + /// + /// Deserializes the into a + /// + /// the element to deserialize + /// the + /// if the can't be parsed into the + internal static VcardTelephoneNumberKind Deserialize(JsonElement jsonElement) + { + var value = jsonElement.GetString(); + + return value switch + { + "WORK" => VcardTelephoneNumberKind.WORK, + "HOME" => VcardTelephoneNumberKind.HOME, + "VOICE" => VcardTelephoneNumberKind.VOICE, + "TEXT" => VcardTelephoneNumberKind.TEXT, + "FAX" => VcardTelephoneNumberKind.FAX, + "CELL" => VcardTelephoneNumberKind.CELL, + "PAGER" => VcardTelephoneNumberKind.PAGER, + "TEXTPHONE" => VcardTelephoneNumberKind.TEXTPHONE, + "VIDEO" => VcardTelephoneNumberKind.VIDEO, + _ => throw new InvalidDataException($"{value} is not a valid for VcardTelephoneNumberKind") + }; + } + } +} + +// ------------------------------------------------------------------------------------------------ +// --------THIS IS AN AUTOMATICALLY GENERATED FILE. ANY MANUAL CHANGES WILL BE OVERWRITTEN!-------- +// ------------------------------------------------------------------------------------------------ diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index 761a6fdca..14c3d6b0f 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -7,26 +7,27 @@ 26.6.0 CDP4 JSON Serialization Library Copyright © RHEA System S.A. - Sam, Merlin, Alex, Naron, Alexander, Yevhen, Nathanael + Sam, Merlin, Alex, Naron, Alexander, Yevhen, Nathanael, Jaime, Antoine CDP4JsonSerializer-CE true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition - true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true cdp4-icon.png true true - snupkg https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git CDP COMET ECSS-E-TM-10-25 JSON LGPL-3.0-only [BUMP] To CDP4Common 26.6.0 - README.md + 11.0 + + @@ -36,21 +37,10 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/CDP4JsonSerializer/Cdp4JsonSerializer.cs b/CDP4JsonSerializer/Cdp4JsonSerializer.cs index 349731f91..2d72690bf 100644 --- a/CDP4JsonSerializer/Cdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/Cdp4JsonSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer { @@ -28,17 +28,15 @@ namespace CDP4JsonSerializer using System.Collections.Generic; using System.Diagnostics; using System.IO; + using System.Text.Json; + using System.Text.Json.Serialization; using CDP4Common.MetaInfo; using CDP4JsonSerializer.JsonConverter; - using Newtonsoft.Json; - using Newtonsoft.Json.Converters; - using Newtonsoft.Json.Serialization; - using NLog; - + using Thing = CDP4Common.DTO.Thing; /// @@ -52,7 +50,7 @@ public class Cdp4JsonSerializer : ICdp4JsonSerializer private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); /// - /// Initializes a new instance of the class. + /// Initializes a new instance of the class. /// /// /// The meta Info Provider. @@ -66,12 +64,17 @@ public Cdp4JsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedV } /// - /// Initializes a new instance of the class. + /// Initializes a new instance of the class. /// public Cdp4JsonSerializer() { } + /// + /// Gets or sets the options for the serializer + /// + public JsonSerializerOptions JsonSerializerOptions { get; private set; } + /// /// Gets or sets the data model version for this request. /// @@ -83,14 +86,19 @@ public Cdp4JsonSerializer() public IMetaDataProvider MetaInfoProvider { get; private set; } /// - /// Initialize this instance with the required and supported + /// Initialize this instance with the required and supported /// - /// The - /// The supported - public void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) + /// The + /// The supported + public virtual void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) { this.MetaInfoProvider = metaInfoProvider; this.RequestDataModelVersion = supportedVersion; + + this.JsonSerializerOptions = SerializerOptions.Copy(); + this.JsonSerializerOptions.Converters.Add(new ThingSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); + this.JsonSerializerOptions.Converters.Add(new ClasslessDtoSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); + this.JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter(null, false)); } /// @@ -115,31 +123,25 @@ public void SerializeToStream(object collectionSource, Stream outputStream) } var sw = Stopwatch.StartNew(); - - var serializer = this.CreateJsonSerializer(); - Logger.Trace("initializing JsonTextWriter"); - var jsonWriter = new JsonTextWriter(new StreamWriter(outputStream)); - - Logger.Trace("Serialize to JsonTextWriter"); - serializer.Serialize(jsonWriter, collectionSource); - jsonWriter.Flush(); + Logger.Trace("initializing Serialization"); + JsonSerializer.Serialize(outputStream, collectionSource, this.JsonSerializerOptions); sw.Stop(); Logger.Debug("SerializeToStream finished in {0} [ms]", sw.ElapsedMilliseconds); } /// - /// Serialize the to a JSON stream + /// Serialize the to a JSON stream /// /// - /// The + /// The /// /// /// The output stream to which the serialized JSON objects are written /// /// - /// A value indicating whether the contained shall be included in the JSON stream + /// A value indicating whether the contained shall be included in the JSON stream /// /// A JSON stream public void SerializeToStream(CDP4Common.CommonData.Thing source, Stream outputStream, bool isExtentDeep) @@ -160,9 +162,11 @@ public void SerializeToStream(CDP4Common.CommonData.Thing source, Stream outputS } var dtos = new List(); + if (isExtentDeep) { var pocos = source.QueryContainedThingsDeep(); + foreach (var poco in pocos) { dtos.Add(poco.ToDto()); @@ -179,10 +183,10 @@ public void SerializeToStream(CDP4Common.CommonData.Thing source, Stream outputS } /// - /// Serialize the to a JSON string + /// Serialize the to a JSON string /// - /// The - /// A value indicating whether the contained shall be processed + /// The + /// A value indicating whether the contained shall be processed /// The JSON string public string SerializeToString(CDP4Common.CommonData.Thing source, bool isExtentDeep) { @@ -190,27 +194,24 @@ public string SerializeToString(CDP4Common.CommonData.Thing source, bool isExten { throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); } - - string jsonString; + Logger.Trace("initializing MemoryStream"); - using (var stream = new MemoryStream()) - { - this.SerializeToStream(source, stream, isExtentDeep); + using var stream = new MemoryStream(); - Logger.Trace("rewind MemoryStream"); - stream.Position = 0; + this.SerializeToStream(source, stream, isExtentDeep); - Logger.Trace("initializing StreamReader"); - using (var reader = new StreamReader(stream)) - { - var sw = new Stopwatch(); - sw.Start(); - jsonString = reader.ReadToEnd(); - sw.Stop(); - Logger.Trace("write json stream to json string in {0} [ms]", sw.ElapsedMilliseconds); - } - } + Logger.Trace("rewind MemoryStream"); + stream.Position = 0; + + Logger.Trace("initializing StreamReader"); + using var reader = new StreamReader(stream); + + var sw = new Stopwatch(); + sw.Start(); + var jsonString = reader.ReadToEnd(); + sw.Stop(); + Logger.Trace("write json stream to json string in {0} [ms]", sw.ElapsedMilliseconds); return jsonString; } @@ -222,7 +223,7 @@ public string SerializeToString(CDP4Common.CommonData.Thing source, bool isExten /// The content Stream. /// /// - /// The the deserialized collection of . + /// The the deserialized collection of . /// public IEnumerable Deserialize(Stream contentStream) { @@ -248,43 +249,48 @@ public T Deserialize(Stream contentStream) throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); } - var serializer = this.CreateJsonSerializer(); - - T data; - using (var streamReader = new StreamReader(contentStream)) - using (var jsonTextReader = new JsonTextReader(streamReader)) - { - var sw = new Stopwatch(); - sw.Start(); - data = serializer.Deserialize(jsonTextReader); - Logger.Trace("Deserialize from stream in {0} [ms]", sw.ElapsedMilliseconds); - } - + var sw = new Stopwatch(); + sw.Start(); + var data = JsonSerializer.Deserialize(contentStream, this.JsonSerializerOptions); + Logger.Trace("Deserialize from stream in {0} [ms]", sw.ElapsedMilliseconds); return data; } /// - /// Create a + /// Serialize an object into a string /// - /// - /// an instance of - /// - protected JsonSerializer CreateJsonSerializer() + /// The object to serialize + /// The serialized string + /// + /// If the or + /// has not been initialized + /// + public string SerializeToString(object toSerialize) { - Logger.Trace("initializing JsonSerializer"); - var serializer = new JsonSerializer + if (this.RequestDataModelVersion == null || this.MetaInfoProvider == null) { - ContractResolver = new CamelCasePropertyNamesContractResolver(), - NullValueHandling = NullValueHandling.Ignore - }; - - Logger.Trace("register converters"); - serializer.Converters.Add(new ThingSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); - serializer.Converters.Add(new ClasslessDtoSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); - serializer.Converters.Add(new ClassKindConverter()); - serializer.Converters.Add(new StringEnumConverter()); - - return serializer; + throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); + } + + Logger.Trace("initializing MemoryStream"); + + using var stream = new MemoryStream(); + + this.SerializeToStream(toSerialize, stream); + + Logger.Trace("rewind MemoryStream"); + stream.Position = 0; + + Logger.Trace("initializing StreamReader"); + using var reader = new StreamReader(stream); + + var sw = new Stopwatch(); + sw.Start(); + var jsonString = reader.ReadToEnd(); + sw.Stop(); + Logger.Trace("write json stream to json string in {0} [ms]", sw.ElapsedMilliseconds); + + return jsonString; } } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/DtoSerializer/BaseThingSerializer.cs b/CDP4JsonSerializer/DtoSerializer/BaseThingSerializer.cs index ddff2cbdb..a10662dd8 100644 --- a/CDP4JsonSerializer/DtoSerializer/BaseThingSerializer.cs +++ b/CDP4JsonSerializer/DtoSerializer/BaseThingSerializer.cs @@ -1,46 +1,54 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer { using System; + using CDP4Common.Comparers; using CDP4Common.Types; + using NLog; + /// /// Abstract supertype from which all derive /// public abstract class BaseThingSerializer { + /// + /// The NLog logger + /// + protected static readonly Logger Logger = LogManager.GetCurrentClassLogger(); + /// /// The used to compare 2 s /// - protected readonly GuidComparer guidComparer = new GuidComparer(); + protected readonly GuidComparer GuidComparer = new(); /// /// The used to compare 2 s /// - protected readonly OrderedItemComparer orderedItemComparer = new OrderedItemComparer(); + protected readonly OrderedItemComparer OrderedItemComparer = new(); } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/DtoSerializer/IThingSerializer.cs b/CDP4JsonSerializer/DtoSerializer/IThingSerializer.cs index fee89b190..cd501b189 100644 --- a/CDP4JsonSerializer/DtoSerializer/IThingSerializer.cs +++ b/CDP4JsonSerializer/DtoSerializer/IThingSerializer.cs @@ -1,51 +1,56 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer { using System; - using System.Collections.Generic; + using System.Text.Json; + using System.Text.Json.Nodes; using CDP4Common.DTO; - using Newtonsoft.Json.Linq; - /// - /// Definition of the used to serialize instances of to a + /// Definition of the used to serialize instances of to a + /// /// public interface IThingSerializer { /// - /// Gets the map containing the serialization method for each property + /// Serialize a value for a property into a /// - IReadOnlyDictionary> PropertySerializerMap { get; } + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion); /// - /// Serialize the + /// Serializes a into an /// - /// The to serialize - /// The - JObject Serialize(Thing thing); + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion); } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/Helper/SerializerHelper.cs b/CDP4JsonSerializer/Helper/SerializerHelper.cs index f7cd175de..c1f22cfc9 100644 --- a/CDP4JsonSerializer/Helper/SerializerHelper.cs +++ b/CDP4JsonSerializer/Helper/SerializerHelper.cs @@ -1,53 +1,56 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer { using System; using System.Collections.Generic; using System.Linq; + using System.Text.Json; using System.Text.RegularExpressions; using CDP4Common.Types; - using Newtonsoft.Json; - using Newtonsoft.Json.Linq; - /// /// Utility method to convert a JSON token to a CDP4 type /// public static class SerializerHelper { + /// + /// Gets the format of the to use + /// + public const string DateTimeFormat = "yyyy-MM-ddTHH:mm:ss.fffZ"; + /// /// Regex used for conversion of Json value to string /// - private static readonly Regex JsonToValueArrayRegex = new Regex(@"^\[(.*)\]$", RegexOptions.Singleline); - + private static readonly Regex JsonToValueArrayRegex = new(@"^\[(.*)\]$", RegexOptions.Singleline); + /// /// Regex used for conversion of HStore value to string /// - private static readonly Regex HstoreToValueArrayRegex = new Regex(@"^\{(.*)\}$", RegexOptions.Singleline); + private static readonly Regex HstoreToValueArrayRegex = new(@"^\{(.*)\}$", RegexOptions.Singleline); /// /// Convert a string to a @@ -78,44 +81,82 @@ public static string ToJsonString(this ValueArray valueArray) } /// - /// Serialize a to a + /// Writes an into an /// - /// The - /// The - public static JObject ToJsonObject(this OrderedItem orderedItem) + /// The + /// The to write + public static void WriteOrderedItem(this Utf8JsonWriter writer, OrderedItem orderedItem) { - var jsonObject = new JObject(); - jsonObject.Add("k", new JValue(orderedItem.K)); + writer.WriteStartObject(); + writer.WriteNumber("k"u8, orderedItem.K); if (orderedItem.M != null) { - jsonObject.Add("m", new JValue(orderedItem.M)); + writer.WriteNumber("m"u8, orderedItem.M.Value); + } + + writer.WritePropertyName("v"u8); + + switch (orderedItem.V) + { + case string stringValue: + writer.WriteStringValue(stringValue); + break; + case Guid guidValue: + writer.WriteStringValue(guidValue); + break; + case bool boolValue: + writer.WriteBooleanValue(boolValue); + break; + case int intValue: + writer.WriteNumberValue(intValue); + break; + case double doubleValue: + writer.WriteNumberValue(doubleValue); + break; + case float floatValue: + writer.WriteNumberValue(floatValue); + break; + default: + throw new NotSupportedException($"The type {orderedItem.V.GetType().Name} is not supported for the {nameof(OrderedItem)} serialization"); } - jsonObject.Add("v", new JValue(orderedItem.V)); - return jsonObject; + writer.WriteEndObject(); } /// - /// Instantiate a from a + /// Instantiate a from a /// - /// The + /// The /// The - public static IEnumerable ToOrderedItemCollection(this JToken jsonToken) + public static IEnumerable ToOrderedItemCollection(this JsonElement jsonToken) { var list = new List(); - foreach (var token in jsonToken) + + foreach (var prop in jsonToken.EnumerateArray()) { + var keyProp = prop.GetProperty("k"); + var valueKind = keyProp.ValueKind; + var key = long.MinValue; + + if (valueKind == JsonValueKind.String) + { + key = Convert.ToInt64(keyProp.GetString()); + } + else if (valueKind == JsonValueKind.Number) + { + key = keyProp.GetInt64(); + } + var orderedItem = new OrderedItem { - K = token["k"].ToObject(), - V = token["v"].ToString() + K = key, + V = prop.GetProperty("v").GetString(), }; - var move = token["m"]; - if (move != null) + if (prop.TryGetProperty("m", out var value) && value.ValueKind != JsonValueKind.Null) { - orderedItem.M = move.ToObject(); + orderedItem.M = value.GetInt64(); } list.Add(orderedItem); @@ -124,19 +165,6 @@ public static IEnumerable ToOrderedItemCollection(this JToken jsonT return list; } - /// - /// Assert Whether a is null or empty - /// - /// The - /// True if the is null or empty - public static bool IsNullOrEmpty(this JToken token) - { - return (token == null) || - (token.Type == JTokenType.Array && !token.HasValues) || - (token.Type == JTokenType.Object && !token.HasValues) || - (token.Type == JTokenType.Null); - } - /// /// Convert a string to a /// @@ -159,7 +187,7 @@ private static ValueArray ToValueArray(string valueArrayString, Regex rege foreach (Match match in test) { - stringValues.Add(JsonConvert.DeserializeObject($"\"{match.Groups[1].Value}\"")); + stringValues.Add(JsonSerializer.Deserialize($"\"{match.Groups[1].Value}\"")); } var convertedStringList = stringValues.Select(m => (T)Convert.ChangeType(m, typeof(T))).ToList(); @@ -189,7 +217,7 @@ private static IEnumerable ValueArrayToStringList(ValueArray val for (var i = 0; i < items.Count; i++) { - items[i] = $"{JsonConvert.SerializeObject(items[i])}"; + items[i] = $"{JsonSerializer.Serialize(items[i], SerializerOptions.Options)}"; } return items; diff --git a/CDP4JsonSerializer/ICdp4JsonSerializer.cs b/CDP4JsonSerializer/ICdp4JsonSerializer.cs index 26b86e066..79d3bb656 100644 --- a/CDP4JsonSerializer/ICdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/ICdp4JsonSerializer.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer { @@ -99,17 +99,14 @@ public interface ICdp4JsonSerializer IEnumerable Deserialize(Stream contentStream); /// - /// Convenience method that deserializes the passed in JSON content stream + /// Serialize an object into a string /// - /// - /// The type info for which deserialization will be performed - /// - /// - /// The content Stream. - /// - /// - /// The the deserialized instance of the specified Type - /// - T Deserialize(Stream contentStream); + /// The object to serialize + /// The serialized string + /// + /// If the or + /// has not been initialized + /// + string SerializeToString(object toSerialize); } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/JsonConverter/ClassKindConverter.cs b/CDP4JsonSerializer/JsonConverter/ClassKindConverter.cs deleted file mode 100644 index 0db4d1766..000000000 --- a/CDP4JsonSerializer/JsonConverter/ClassKindConverter.cs +++ /dev/null @@ -1,50 +0,0 @@ -// -------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public License -// along with this program; if not, write to the Free Software Foundation, -// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -// -// -------------------------------------------------------------------------------------------------------------------- - -namespace CDP4JsonSerializer.JsonConverter -{ - using System; - - using CDP4Common.CommonData; - - using Newtonsoft.Json.Converters; - - /// - /// Specific converter for values. - /// - public class ClassKindConverter : StringEnumConverter - { - /// - /// Determines whether this instance can convert the specified object type. - /// - /// Type of the object. - /// - /// true if this instance can convert the specified object type; otherwise, false. - /// - public override bool CanConvert(Type objectType) - { - return objectType == typeof(ClassKind); - } - } -} diff --git a/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs b/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs index e18948503..969d8bd09 100644 --- a/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs +++ b/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs @@ -1,47 +1,48 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.JsonConverter { using System; - using System.Collections.Generic; + using System.Text.Json; + using System.Text.Json.Nodes; + using System.Text.Json.Serialization; + using CDP4Common; using CDP4Common.MetaInfo; using CDP4Common.Polyfills; + using CDP4JsonSerializer.Helper; - using Newtonsoft.Json; - using Newtonsoft.Json.Linq; + using NLog; using Dto = CDP4Common.DTO; /// - /// The for s + /// The for s /// - public class ClasslessDtoSerializer : JsonConverter + public class ClasslessDtoSerializer : JsonConverter { /// /// The NLog logger @@ -49,149 +50,96 @@ public class ClasslessDtoSerializer : JsonConverter private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); /// - /// The + /// The data model version for this request. /// - private readonly IMetaDataProvider metaDataProvider; + private readonly Version dataModelVersion; /// - /// The data model version for this request. + /// The /// - private readonly Version dataModelVersion; + private readonly IMetaDataProvider metaDataProvider; /// - /// Initializes a new instance of the class. + /// Initializes a new instance of the class. /// /// - /// The + /// The /// - /// The supported + /// The supported public ClasslessDtoSerializer(IMetaDataProvider metaDataProvider, Version dataModelVersion) { this.metaDataProvider = metaDataProvider; this.dataModelVersion = dataModelVersion; } - /// - /// Gets a value indicating whether this converter supports JSON read. - /// - public override bool CanRead - { - get { return true; } - } - - /// - /// Gets a value indicating whether this converter supports JSON write. - /// - public override bool CanWrite - { - get { return true; } - } - /// /// Override of the can convert type check. /// - /// + /// /// The object type. /// /// /// true if this converter is to be used. /// - public override bool CanConvert(Type objectType) + public override bool CanConvert(Type typeToConvert) { - return typeof(ClasslessDTO).QueryIsAssignableFrom(objectType); + return typeof(ClasslessDTO).QueryIsAssignableFrom(typeToConvert); } /// - /// Write JSON. + /// Tries to deserialize a JSON into a /// - /// - /// The JSON writer. - /// - /// - /// The value object. - /// - /// - /// The JSON serializer. - /// - public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) + /// the + /// the to convert + /// the options of the serializer + /// the + public override ClasslessDTO Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) { - var classlessDto = (ClasslessDTO)value; - - var typeName = classlessDto["ClassKind"].ToString(); - var classVersion = new Version(this.metaDataProvider.GetClassVersion(typeName)); - if (classVersion > this.dataModelVersion) - { - // skip type serialization if the data version is larger then the request data model version - return; - } - - var jsonObject = ((ClasslessDTO)value).ToJsonObject(); - - var nonSerializablePropeties = new List(); - foreach (var kvp in jsonObject) + if (!JsonElement.TryParseValue(ref reader, out var jsonElement)) { - var propertyVersion = new Version(this.metaDataProvider.GetPropertyVersion(typeName, Helper.Utils.CapitalizeFirstLetter(kvp.Key))); - if (propertyVersion > this.dataModelVersion) - { - nonSerializablePropeties.Add(kvp.Key); - } + Logger.Error("The data object in the JSON array could not be cast to a JsonElement type."); + throw new NullReferenceException("The data object in the JSON array could not be cast to a JsonElement type."); } - foreach (var nonSerializablePropety in nonSerializablePropeties) - { - jsonObject.Remove(nonSerializablePropety); - } + var dto = jsonElement?.ToDto(); + var classlessDto = this.GenerateClasslessDto(jsonElement.Value, dto); - jsonObject.WriteTo(writer); + return classlessDto; } /// - /// Override of the Read JSON method. + /// Write a JSON /// - /// - /// The JSON reader. - /// - /// - /// The type information of the object. - /// - /// - /// The existing object value. - /// - /// - /// The JSON serializer. - /// - /// - /// A deserialized instance. - /// - public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) + /// the + /// the to serialize + /// the options of the serializer + public override void Write(Utf8JsonWriter writer, ClasslessDTO value, JsonSerializerOptions options) { - // load object from stream - var jsonObject = JObject.Load(reader); + var typeName = value["ClassKind"].ToString(); + var classVersion = new Version(this.metaDataProvider.GetClassVersion(typeName)); - if (jsonObject == null) + if (classVersion > this.dataModelVersion) { - Logger.Error("The data object in the JSON array could not be cast to a JObject type."); - throw new NullReferenceException("The data object in the JSON array could not be cast to a JObject type."); + // skip type serialization if the data version is larger then the request data model version + return; } - var dto = jsonObject.ToDto(); - var classlessDto = this.GenerateClasslessDto(jsonObject, dto); - - return classlessDto; + value.SerializeClasslessDto(writer, this.dataModelVersion); } /// - /// Create a from a and a partial + /// Create a from a and a partial /// - /// The - /// The - /// The generated - private ClasslessDTO GenerateClasslessDto(JObject jsonObject, Dto.Thing dto) + /// The + /// The + /// The generated + private ClasslessDTO GenerateClasslessDto(JsonElement jsonObject, Dto.Thing dto) { var metainfo = this.metaDataProvider.GetMetaInfo(dto.ClassKind.ToString()); var classlessDto = new ClasslessDTO(); - foreach (var property in jsonObject.Properties()) + + foreach (var property in jsonObject.EnumerateObject()) { var propertyName = Utils.CapitalizeFirstLetter(property.Name); classlessDto.Add(propertyName, metainfo.GetValue(propertyName, dto)); @@ -200,4 +148,4 @@ private ClasslessDTO GenerateClasslessDto(JObject jsonObject, Dto.Thing dto) return classlessDto; } } -} \ No newline at end of file +} diff --git a/CDP4JsonSerializer/JsonConverter/ThingConverterExtensions.cs b/CDP4JsonSerializer/JsonConverter/ThingConverterExtensions.cs new file mode 100644 index 000000000..5dfa81c43 --- /dev/null +++ b/CDP4JsonSerializer/JsonConverter/ThingConverterExtensions.cs @@ -0,0 +1,111 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4JsonSerializer.JsonConverter +{ + using System; + using System.Linq; + + using CDP4Common.DTO; + using CDP4Common.MetaInfo; + + /// + /// The purpose of the is to implement extra business logic for hand-coded serialization to + /// decide to include or exclude classes from the serialization process + /// + public class ThingConverterExtensions + { + /// + /// Asserts whether an object shall be serialized or not + /// + /// + /// the for which the serialization is to be asserted + /// + /// + /// The used to provide meta data + /// + /// + /// The data model version to be used to determine whether a class shall be serialized or not + /// + /// + /// returns true when the object shall be serialzed, false if not + /// + public bool AssertSerialization(object value, IMetaDataProvider metaDataProvider, Version version) + { + if (value is PersonPermission personPermission) + { + var classVersion = new Version(metaDataProvider.GetClassVersion(personPermission.ObjectClass.ToString())); + + if (classVersion > version) + { + return false; + } + } + + if (value is ParticipantPermission participantPermission) + { + var classVersion = new Version(metaDataProvider.GetClassVersion(participantPermission.ObjectClass.ToString())); + + if (classVersion > version) + { + return false; + } + } + + return true; + } + + /// + /// Checks the 's property for compatibility + /// + /// + /// the for which the serialization is to be asserted + /// + /// + /// The used to provide meta data + /// + /// + /// The data model version to be used to determine whether a class shall be serialized or not + /// + public void CheckCategoryPermissibleClasses(object value, IMetaDataProvider metaDataProvider, Version version) + { + if (value is Category category) + { + var permissibleClasses = category.PermissibleClass.ToList(); + + foreach (var permissibleClass in permissibleClasses) + { + var permissibleClassVersion = new Version(metaDataProvider.GetClassVersion(permissibleClass.ToString())); + + if (permissibleClassVersion <= version) + { + continue; + } + + category.PermissibleClass.Remove(permissibleClass); + } + } + } + } +} diff --git a/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs b/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs index eaad81729..bc8bb911b 100644 --- a/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs +++ b/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs @@ -1,47 +1,43 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4JsonSerializer.JsonConverter { using System; - using System.Collections.Generic; - using System.Linq; + using System.Text.Json; + using System.Text.Json.Serialization; using CDP4Common.DTO; - using CDP4Common.Extensions; using CDP4Common.MetaInfo; using CDP4Common.Polyfills; - using Newtonsoft.Json; - using Newtonsoft.Json.Linq; - using NLog; /// - /// The that is responsible for (De)serialization on a + /// The that is responsible for (De)serialization on a /// - public class ThingSerializer : JsonConverter + public class ThingSerializer : JsonConverter { /// /// The NLog logger @@ -54,10 +50,20 @@ public class ThingSerializer : JsonConverter private readonly Version dataModelVersion; /// - /// The used to determine whether a class is to be serialized or not + /// Override default null handling + /// + public override bool HandleNull => true; + + /// + /// The used to determine whether a class is to be serialized or not /// private readonly ThingConverterExtensions thingConverterExtensions; + /// + /// Gets or sets the meta info provider. + /// + private IMetaDataProvider MetaInfoProvider { get; set; } + /// /// Initializes a new instance of the class. /// @@ -75,21 +81,6 @@ public ThingSerializer(IMetaDataProvider metaInfoProvider, Version dataModelVers this.thingConverterExtensions = new ThingConverterExtensions(); } - /// - /// Gets a value indicating whether this converter supports JSON read. - /// - public override bool CanRead => true; - - /// - /// Gets a value indicating whether this converter supports JSON write. - /// - public override bool CanWrite => true; - - /// - /// Gets or sets the meta info provider. - /// - private IMetaDataProvider MetaInfoProvider { get; set; } - /// /// Override of the can convert type check. /// @@ -105,18 +96,33 @@ public override bool CanConvert(Type objectType) } /// - /// Write JSON. + /// Tries to deserialize a JSON into a /// - /// - /// The JSON writer. - /// - /// - /// The value object. - /// - /// - /// The JSON serializer. - /// - public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) + /// the + /// the to convert + /// the options of the serializer + /// the + public override Thing Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) + { + // load object from stream + if (!JsonElement.TryParseValue(ref reader, out var jsonElement)) + { + Logger.Error("The data object in the JSON array could not be cast to a JsonElement type."); + throw new NullReferenceException("The data object in the JSON array could not be cast to a JsonElement type."); + } + + var newThing = jsonElement?.ToDto(); + + return newThing; + } + + /// + /// Write a JSON + /// + /// the + /// the to serialize + /// the options of the serializer + public override void Write(Utf8JsonWriter writer, Thing value, JsonSerializerOptions options) { var typeName = value.GetType().Name; var classVersion = new Version(this.MetaInfoProvider.GetClassVersion(typeName)); @@ -134,62 +140,7 @@ public override void WriteJson(JsonWriter writer, object value, JsonSerializer s } this.thingConverterExtensions.CheckCategoryPermissibleClasses(value, this.MetaInfoProvider, this.dataModelVersion); - - var jsonObject = ((Thing)value).ToJsonObject(); - - // remove versioned properties - var nonSerializableProperties = new List(); - - foreach (var kvp in jsonObject) - { - var propertyVersion = new Version(this.MetaInfoProvider.GetPropertyVersion(typeName, Helper.Utils.CapitalizeFirstLetter(kvp.Key))); - - if (propertyVersion > this.dataModelVersion) - { - nonSerializableProperties.Add(kvp.Key); - } - } - - foreach (var nonSerializableProperty in nonSerializableProperties) - { - jsonObject.Remove(nonSerializableProperty); - } - - jsonObject.WriteTo(writer); - } - - /// - /// Override of the Read JSON method. - /// - /// - /// The JSON reader. - /// - /// - /// The type information of the object. - /// - /// - /// The existing object value. - /// - /// - /// The JSON serializer. - /// - /// - /// A deserialized instance. - /// - public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) - { - // load object from stream - var jsonObject = JObject.Load(reader); - - if (jsonObject == null) - { - Logger.Error("The data object in the JSON array could not be cast to a JObject type."); - throw new NullReferenceException("The data object in the JSON array could not be cast to a JObject type."); - } - - var newThing = jsonObject.ToDto(); - - return newThing; + value.SerializeThing(writer, this.dataModelVersion); } } } diff --git a/CDP4JsonSerializer/Properties/AssemblyInfo.cs b/CDP4JsonSerializer/Properties/AssemblyInfo.cs index fd03f6cc9..c9db8d273 100644 --- a/CDP4JsonSerializer/Properties/AssemblyInfo.cs +++ b/CDP4JsonSerializer/Properties/AssemblyInfo.cs @@ -26,5 +26,6 @@ using System.Runtime.CompilerServices; -[assembly: InternalsVisibleTo("CDP4JsonSerializer.Tests")] -[assembly: InternalsVisibleTo("CDP4JsonSerializer.NetCore.Tests")] \ No newline at end of file +[assembly: InternalsVisibleTo("Cdp4JsonSerializer")] +[assembly: InternalsVisibleTo("Cdp4JsonSerializer.Tests")] +[assembly: InternalsVisibleTo("Cdp4JsonSerializer.NetCore.Tests")] \ No newline at end of file diff --git a/CDP4JsonSerializer/SerializerOptions.cs b/CDP4JsonSerializer/SerializerOptions.cs new file mode 100644 index 000000000..ac115c6b1 --- /dev/null +++ b/CDP4JsonSerializer/SerializerOptions.cs @@ -0,0 +1,88 @@ +// ------------------------------------------------------------------------------------------------------------------------------- +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 3 of the License, or (at your option) any later version. +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with this program; if not, write to the Free Software Foundation, +// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +// +// ------------------------------------------------------------------------------------------------------------------------------- + +namespace CDP4JsonSerializer +{ + using System.Text.Json; + + /// + /// Static class with the options used in the serializer + /// + public class SerializerOptions + { + /// + /// Backing field for the property + /// + private static JsonSerializerOptions options; + + /// + /// Object to lock the options + /// + private static readonly object Lock = new(); + + /// + /// Creates a new instance of type + /// + private SerializerOptions() + { + } + + /// + /// Gets the instance that it's been used of this + /// + public static JsonSerializerOptions Options + { + get + { + if (options == null) + { + lock (Lock) + { + if (options == null) + { + options = new JsonSerializerOptions() + { + WriteIndented = false, + Encoder = System.Text.Encodings.Web.JavaScriptEncoder.UnsafeRelaxedJsonEscaping, + PropertyNameCaseInsensitive = true, + NumberHandling = System.Text.Json.Serialization.JsonNumberHandling.AllowReadingFromString + }; + } + } + } + + return options; + } + } + + /// + /// Copies the and returns a new instance + /// + /// the new instance + public static JsonSerializerOptions Copy() + { + return new JsonSerializerOptions(Options); + } + } +} diff --git a/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj b/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj index ed51f420b..1895939a8 100644 --- a/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj +++ b/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj @@ -11,7 +11,8 @@ - + + diff --git a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs index bb7920766..26b2eac6e 100644 --- a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -49,7 +49,8 @@ namespace CDP4ServicesDal.Tests using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; using NUnit.Framework; @@ -92,7 +93,7 @@ public void Setup() this.siteDirectory = new SiteDirectory(Guid.Parse("f13de6f8-b03a-46e7-a492-53b2f260f294"), this.session.Assembler.Cache, this.uri); var lazySiteDirectory = new Lazy(() => this.siteDirectory); lazySiteDirectory.Value.Cache.TryAdd(new CacheKey(lazySiteDirectory.Value.Iid, null), lazySiteDirectory); - + this.jsonSerializerOptions = new JsonSerializerOptions() { PropertyNamingPolicy = JsonNamingPolicy.CamelCase, @@ -183,7 +184,7 @@ public void Verify_That_When_constructed_with_null_httpclient_throws_exception() HttpClient httpClient = null; Assert.Throws(() => new CdpServicesDal(httpClient)); } - + [Test] [Category("WebServicesDependent")] public async Task VerifThatAClosedDalCannotBeClosedAgain() @@ -254,17 +255,18 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() Assert.Throws(() => this.dal.Close()); } - [Test] + [TestCase(true)] + [TestCase(false)] [Category("WebServicesDependent")] - public async Task VerifyThatReadReturnsCorrectDTO() + public async Task VerifyThatReadReturnsCorrectDTO(bool isMessagePackSupported) { - this.dal = new CdpServicesDal(); + this.dal = new CdpServicesDal(isMessagePackSupported); var returned = (await this.dal.Open(this.credentials, this.cancelationTokenSource.Token)).ToList(); Assert.NotNull(returned); Assert.IsNotEmpty(returned); - var sd = returned.First(); + var sd = returned.First(x => x.ClassKind == ClassKind.SiteDirectory); var attributes = new QueryAttributes(); var readResult = await dal.Read(sd, this.cancelationTokenSource.Token, attributes); @@ -326,6 +328,7 @@ public void VerifyThatPostBodyIsCorrectlyResolves() IsSynonym = false, LanguageCode = "en", }; + testDtoOriginal.AddContainer(ClassKind.DomainOfExpertise, domainOfExpertiseIid); testDtoOriginal.AddContainer(ClassKind.SiteDirectory, siteDirecortoryIid); @@ -335,6 +338,7 @@ public void VerifyThatPostBodyIsCorrectlyResolves() IsSynonym = true, LanguageCode = "en", }; + testDtoModified.AddContainer(ClassKind.DomainOfExpertise, domainOfExpertiseIid); testDtoModified.AddContainer(ClassKind.SiteDirectory, siteDirecortoryIid); @@ -343,6 +347,7 @@ public void VerifyThatPostBodyIsCorrectlyResolves() Content = "somecontent", LanguageCode = "en", }; + testDtoOriginal2.AddContainer(ClassKind.DomainOfExpertise, domainOfExpertiseIid); testDtoOriginal2.AddContainer(ClassKind.SiteDirectory, siteDirecortoryIid); @@ -351,6 +356,7 @@ public void VerifyThatPostBodyIsCorrectlyResolves() Content = "somecontent2", LanguageCode = "en", }; + testDtoModified2.AddContainer(ClassKind.DomainOfExpertise, domainOfExpertiseIid); testDtoModified2.AddContainer(ClassKind.SiteDirectory, siteDirecortoryIid); @@ -477,10 +483,11 @@ public async Task AssemblerSynchronizePerformanceTest() await assembler.Clear(); } }, Throws.Nothing); - + var synchronizeMeanElapsedTime = elapsedTimes.Average(); var maxElapsedTime = elapsedTimes.Max(); var minElapsedTime = elapsedTimes.Min(); + // 204.64 | 181 | 458 ms // refactor: 31.61 | 26 | 283 } @@ -497,7 +504,7 @@ public async Task VerifyThatFileCanBeUploaded() var files = new List { filepath }; var contentHash = "F73747371CFD9473C19A0A7F99BCAB008474C4CA"; - var uri = new Uri("https://cdp4services-test.cdp4.org"); + var uri = new Uri("https://cdp4services-test.cdp4.org"); this.credentials = new Credentials("admin", "pass", uri); var returned = await this.dal.Open(this.credentials, this.cancelationTokenSource.Token); @@ -621,25 +628,24 @@ public async Task Verify_that_opens_returns_expected_result() public async Task Verify_that_open_with_proxy_returns_expected_result() { var proxySettings = new ProxySettings(new Uri("http://tinyproxy:8888")); - + var uri = new Uri("https://cdp4services-test.cdp4.org"); this.credentials = new Credentials("admin", "pass", uri, proxySettings); var dal = new CdpServicesDal(); var result = await dal.Open(this.credentials, new CancellationToken()); - + Assert.NotNull(result); } - + [Test] [Category("WebServicesDependent")] public async Task Verify_that_multiple_read_requests_can_be_made_in_parallel() { var uri = new Uri("https://cdp4services-test.cdp4.org"); var credentials = new Credentials("admin", "pass", uri); - + var dal = new CdpServicesDal(); - var result = await dal.Open(credentials, new CancellationToken()); @@ -699,7 +705,7 @@ public async Task VerifyReadCometTask() this.dal = new CdpServicesDal(httpClient); this.SetDalToBeOpen(this.dal); - + var cometTaskId = Guid.NewGuid(); var requestHandler = mockHttp.When($"{CdpServicesDal.CometTaskRoute}/{cometTaskId}"); @@ -748,7 +754,7 @@ public async Task VerifyReadCometTasks() this.dal = new CdpServicesDal(httpClient); this.SetDalToBeOpen(this.dal); - + var requestHandler = mockHttp.When($"{CdpServicesDal.CometTaskRoute}"); var notFoundHttpResponse = new HttpResponseMessage() @@ -764,7 +770,7 @@ public async Task VerifyReadCometTasks() var cometTasks = new List() { - new () + new() { Id = Guid.NewGuid(), Actor = Guid.NewGuid(), @@ -830,7 +836,7 @@ public async Task VerifyWriteLongRunningTask() newCometTaskResponse.Content = new StringContent(JsonSerializer.Serialize(cometTask, this.jsonSerializerOptions)); SetHttpHeader(newCometTaskResponse, "application/json"); - var longRunningTaskResult = await this.dal.Write(operationContainer,1); + var longRunningTaskResult = await this.dal.Write(operationContainer, 1); Assert.Multiple(() => { @@ -848,7 +854,7 @@ public async Task VerifyWriteLongRunningTask() thingsResponse.Content = new StreamContent(stream); SetHttpHeader(thingsResponse, "application/json"); - longRunningTaskResult = await this.dal.Write(operationContainer,1); + longRunningTaskResult = await this.dal.Write(operationContainer, 1); Assert.Multiple(() => { diff --git a/CDP4ServicesDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs index 3d4f62827..4a5a30208 100644 --- a/CDP4ServicesDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -36,6 +36,8 @@ namespace CDP4ServicesDal.Tests using CDP4Dal.Operations; using CDP4Dal.Permission; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4ServicesDal.NetCore.Tests/OperationModifierTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/OperationModifierTestFixture.cs index dff2ca099..924ad8832 100644 --- a/CDP4ServicesDal.NetCore.Tests/OperationModifierTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/OperationModifierTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -34,6 +34,8 @@ namespace CDP4ServicesDal.Tests using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs index c573a6a4f..02d0ce7e4 100644 --- a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Yevhen Ikonnykov -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -35,34 +35,35 @@ namespace CDP4ServicesDal.Tests using CDP4Common.MetaInfo; using CDP4Common.Types; - using CDP4JsonSerializer; - using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer; + using CDP4ServicesDal.Tests.Helper; - - using Newtonsoft.Json; - + using NUnit.Framework; - + using File = System.IO.File; - + [TestFixture] public class PostOperationTestFixture { - private Cdp4JsonSerializer serializer; + private Cdp4DalJsonSerializer serializer; [SetUp] public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4JsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0)); } [Test] public void Verify_that_deserialization_of_Post_Operation_does_not_throw_an_exception() { var response = File.ReadAllText(Path.Combine(TestContext.CurrentContext.TestDirectory, "TestData/PostOperation.json")); + using (var stream = StreamHelper.GenerateStreamFromString(response)) { var test = this.serializer.Deserialize(stream); @@ -147,25 +148,21 @@ public override void ConstructFromOperation(Operation operation) /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_copy")] public override List Copy { get; set; } } } diff --git a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs index 8da697ecc..1fe4b0b24 100644 --- a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -38,6 +38,7 @@ namespace CDP4ServicesDal.Tests using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; + using CDP4Common.MetaInfo; using CDP4Common.SiteDirectoryData; using CDP4Common.Types; @@ -47,9 +48,10 @@ namespace CDP4ServicesDal.Tests using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; - using Newtonsoft.Json; + using CDP4JsonSerializer; using NUnit.Framework; @@ -76,12 +78,13 @@ public class CdpServicesDalTestFixture private SiteReferenceDataLibrary siteReferenceDataLibrary; private ModelReferenceDataLibrary modelReferenceDataLibrary; private CDPMessageBus messageBus; + private Cdp4JsonSerializer jsonSerializer; [SetUp] public void Setup() { this.cancelationTokenSource = new CancellationTokenSource(); - + this.credentials = new Credentials("admin", "pass", this.uri); this.dal = new CdpServicesDal(); this.messageBus = new CDPMessageBus(); @@ -91,7 +94,8 @@ public void Setup() this.siteDirectory = new SiteDirectory(Guid.Parse("f13de6f8-b03a-46e7-a492-53b2f260f294"), this.session.Assembler.Cache, this.uri); var lazySiteDirectory = new Lazy(() => this.siteDirectory); lazySiteDirectory.Value.Cache.TryAdd(new CacheKey(lazySiteDirectory.Value.Iid, null), lazySiteDirectory); - + var metaDataProvider = new MetaDataProvider(); + this.jsonSerializer = new Cdp4JsonSerializer(metaDataProvider, metaDataProvider.GetMaxSupportedModelVersion()); this.PopulateSiteDirectory(); } @@ -228,17 +232,18 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() Assert.Throws(() => this.dal.Close()); } - [Test] + [TestCase(true)] + [TestCase(false)] [Category("WebServicesDependent")] - public async Task VerifyThatReadReturnsCorrectDTO() + public async Task VerifyThatReadReturnsCorrectDTO(bool isMessagePackSupported) { - this.dal = new CdpServicesDal(); + this.dal = new CdpServicesDal(isMessagePackSupported); var returned = (await this.dal.Open(this.credentials, this.cancelationTokenSource.Token)).ToList(); Assert.NotNull(returned); Assert.IsNotEmpty(returned); - var sd = returned.First(); + var sd = returned.First(x => x.ClassKind == ClassKind.SiteDirectory); var attributes = new QueryAttributes(); var readResult = await this.dal.Read(sd, this.cancelationTokenSource.Token, attributes); @@ -687,7 +692,7 @@ public async Task Verify_that_person_can_be_Posted() Assert.NotNull(resultPerson); } - [Test] + [Test] public async Task VerifyReadCometTask() { var mockHttp = new MockHttpMessageHandler(); @@ -696,7 +701,7 @@ public async Task VerifyReadCometTask() this.dal = new CdpServicesDal(httpClient); this.SetDalToBeOpen(this.dal); - + var cometTaskId = Guid.NewGuid(); var requestHandler = mockHttp.When($"{CdpServicesDal.CometTaskRoute}/{cometTaskId}"); @@ -722,7 +727,7 @@ public async Task VerifyReadCometTask() StatusKind = StatusKind.SUCCEEDED }; - foundHttpResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTask)); + foundHttpResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTask)); SetHttpHeader(foundHttpResponse, "application/json"); var readCometTask = await this.dal.ReadCometTask(cometTaskId, CancellationToken.None); @@ -730,7 +735,7 @@ public async Task VerifyReadCometTask() var messagePackHttpResponse = new HttpResponseMessage(); requestHandler.Respond(_ => messagePackHttpResponse); - messagePackHttpResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTask)); + messagePackHttpResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTask)); SetHttpHeader(messagePackHttpResponse, "application/msgpack"); Assert.That(() => this.dal.ReadCometTask(cometTaskId, CancellationToken.None), Throws.Exception.TypeOf()); @@ -745,7 +750,7 @@ public async Task VerifyReadCometTasks() this.dal = new CdpServicesDal(httpClient); this.SetDalToBeOpen(this.dal); - + var requestHandler = mockHttp.When($"{CdpServicesDal.CometTaskRoute}"); var notFoundHttpResponse = new HttpResponseMessage() @@ -772,7 +777,7 @@ public async Task VerifyReadCometTasks() } }; - foundHttpResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTasks)); + foundHttpResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTasks)); SetHttpHeader(foundHttpResponse, "application/json"); var readCometTasks = await this.dal.ReadCometTasks(CancellationToken.None); @@ -780,7 +785,7 @@ public async Task VerifyReadCometTasks() var messagePackHttpResponse = new HttpResponseMessage(); requestHandler.Respond(_ => messagePackHttpResponse); - messagePackHttpResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTasks)); + messagePackHttpResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTasks)); SetHttpHeader(messagePackHttpResponse, "application/msgpack"); Assert.That(() => this.dal.ReadCometTasks(CancellationToken.None), Throws.Exception.TypeOf()); @@ -826,10 +831,10 @@ public async Task VerifyWriteLongRunningTask() var newCometTaskResponse = new HttpResponseMessage(); requestHandler.Respond(_ => newCometTaskResponse); - newCometTaskResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTask)); + newCometTaskResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTask)); SetHttpHeader(newCometTaskResponse, "application/json"); - var longRunningTaskResult = await this.dal.Write(operationContainer,1); + var longRunningTaskResult = await this.dal.Write(operationContainer, 1); Assert.Multiple(() => { @@ -847,7 +852,7 @@ public async Task VerifyWriteLongRunningTask() thingsResponse.Content = new StreamContent(stream); SetHttpHeader(thingsResponse, "application/json"); - longRunningTaskResult = await this.dal.Write(operationContainer,1); + longRunningTaskResult = await this.dal.Write(operationContainer, 1); Assert.Multiple(() => { @@ -859,7 +864,7 @@ public async Task VerifyWriteLongRunningTask() var messagePackResponse = new HttpResponseMessage(); requestHandler.Respond(_ => messagePackResponse); - messagePackResponse.Content = new StringContent(JsonConvert.SerializeObject(cometTask)); + messagePackResponse.Content = new StringContent(this.jsonSerializer.SerializeToString(cometTask)); SetHttpHeader(messagePackResponse, "application/msgpack"); Assert.That(() => this.dal.Write(operationContainer, 1), Throws.Exception.TypeOf()); } diff --git a/CDP4ServicesDal.Tests/CopyOperationHandlerTestFixture.cs b/CDP4ServicesDal.Tests/CopyOperationHandlerTestFixture.cs index c523778d0..4efa0f6e6 100644 --- a/CDP4ServicesDal.Tests/CopyOperationHandlerTestFixture.cs +++ b/CDP4ServicesDal.Tests/CopyOperationHandlerTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -36,6 +36,8 @@ namespace CDP4ServicesDal.Tests using CDP4Dal.Operations; using CDP4Dal.Permission; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4ServicesDal.Tests/OperationModifierTestFixture.cs b/CDP4ServicesDal.Tests/OperationModifierTestFixture.cs index fc2a7f0fc..fcf4893de 100644 --- a/CDP4ServicesDal.Tests/OperationModifierTestFixture.cs +++ b/CDP4ServicesDal.Tests/OperationModifierTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- -// +// ------------------------------------------------------------------------------------------------------------------------------- +// // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -34,6 +34,8 @@ namespace CDP4ServicesDal.Tests using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs index 3aa18fdb7..02d0ce7e4 100644 --- a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Yevhen Ikonnykov -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal.Tests { @@ -35,14 +35,14 @@ namespace CDP4ServicesDal.Tests using CDP4Common.MetaInfo; using CDP4Common.Types; - using CDP4JsonSerializer; - using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer; + using CDP4ServicesDal.Tests.Helper; - - using Newtonsoft.Json; - + using NUnit.Framework; using File = System.IO.File; @@ -50,19 +50,20 @@ namespace CDP4ServicesDal.Tests [TestFixture] public class PostOperationTestFixture { - private Cdp4JsonSerializer serializer; + private Cdp4DalJsonSerializer serializer; [SetUp] public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4JsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0)); } [Test] public void Verify_that_deserialization_of_Post_Operation_does_not_throw_an_exception() { var response = File.ReadAllText(Path.Combine(TestContext.CurrentContext.TestDirectory, "TestData/PostOperation.json")); + using (var stream = StreamHelper.GenerateStreamFromString(response)) { var test = this.serializer.Deserialize(stream); @@ -88,7 +89,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( originalDomainFileStore.AddContainer(ClassKind.Iteration, iterationIid); originalDomainFileStore.AddContainer(ClassKind.EngineeringModel, engineeringModelIid); - var modifiedDomainFileStore = originalDomainFileStore.DeepClone(); + var modifiedDomainFileStore = originalDomainFileStore.DeepClone(); modifiedDomainFileStore.File.Add(fileIid); var file = new CDP4Common.DTO.File(fileIid, 0); @@ -101,7 +102,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( var fileRevision = new FileRevision(fileRevisionIid, 0); fileRevision.Name = "testfile"; fileRevision.ContentHash = "F73747371CFD9473C19A0A7F99BCAB008474C4CA"; - fileRevision.FileType.Add(new OrderedItem() {K = 1, V = fileTypeIid }); + fileRevision.FileType.Add(new OrderedItem() { K = 1, V = fileTypeIid }); fileRevision.Creator = participantIid; fileRevision.AddContainer(ClassKind.File, fileIid); fileRevision.AddContainer(ClassKind.DomainFileStore, domainFileStoreIid); @@ -122,7 +123,8 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( var postOperation = new CdpPostOperation(new MetaDataProvider(), null); - foreach (var operation in operationContainer.Operations) { + foreach (var operation in operationContainer.Operations) + { postOperation.ConstructFromOperation(operation); } @@ -146,25 +148,21 @@ public override void ConstructFromOperation(Operation operation) /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_copy")] public override List Copy { get; set; } } } diff --git a/CDP4ServicesDal/CDP4ServicesDal.csproj b/CDP4ServicesDal/CDP4ServicesDal.csproj index 0977ea912..7ae08223d 100644 --- a/CDP4ServicesDal/CDP4ServicesDal.csproj +++ b/CDP4ServicesDal/CDP4ServicesDal.csproj @@ -27,6 +27,7 @@ + @@ -39,13 +40,9 @@ - - - - - + diff --git a/CDP4ServicesDal/CdpPostOperation.cs b/CDP4ServicesDal/CdpPostOperation.cs index 1e29338a6..afe1adf8c 100644 --- a/CDP4ServicesDal/CdpPostOperation.cs +++ b/CDP4ServicesDal/CdpPostOperation.cs @@ -1,28 +1,26 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal { @@ -30,16 +28,19 @@ namespace CDP4ServicesDal using System.Collections; using System.Collections.Generic; using System.Linq; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.Dto; using CDP4Common.EngineeringModelData; - using CDP4Common.MetaInfo; + using CDP4Common.MetaInfo; using CDP4Common.SiteDirectoryData; using CDP4Common.Types; + using CDP4Dal; using CDP4Dal.Operations; - using Newtonsoft.Json; + + using CDP4DalCommon.Protocol.Operations; /// /// The CDP POST operation @@ -81,25 +82,21 @@ internal CdpPostOperation(IMetaDataProvider metaDataProvider, ISession session) /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to copy. /// - [JsonProperty("_copy")] public override List Copy { get; set; } /// @@ -154,6 +151,7 @@ private void ResolveUpdate(Operation operation) foreach (var key in original.Keys) { var originalIenumerable = original[key] as IEnumerable; + if (originalIenumerable != null && originalIenumerable.GetType().IsGenericType) { var modifiedIenumerable = (IEnumerable)modifiedFull[key]; @@ -177,6 +175,7 @@ private void ResolveUpdate(Operation operation) List modifiedProperty; var genericTypeArgument = original[key].GetType().GenericTypeArguments[0]; + if (genericTypeArgument == typeof(Guid) || genericTypeArgument == typeof(ClassKind) || genericTypeArgument == typeof(VcardTelephoneNumberKind)) { originalProperty = originalIenumerable.Cast().ToList(); @@ -221,6 +220,7 @@ private void ResolveUpdate(Operation operation) } var possibleDeletions = originalProperty.Except(modifiedProperty).ToList(); + if (possibleDeletions.Count > 0) { // this part will be added to the delete @@ -275,6 +275,7 @@ private void ResolveUpdate(Operation operation) if (listsToAdd.Count > 0) { var updateDto = modified; + foreach (var kvp in listsToAdd) { updateDto.Add(kvp.Key, kvp.Value); @@ -311,18 +312,20 @@ private void ResolveCopy(Operation operation) var source = new CopySource { - Thing = new CopyReference {Iid = operation.OriginalThing.Iid, ClassKind = operation.OriginalThing.ClassKind}, - TopContainer = new CopyReference {Iid = sourcepoco.TopContainer.Iid, ClassKind = sourcepoco.TopContainer.ClassKind}, + Thing = new CopyReference { Iid = operation.OriginalThing.Iid, ClassKind = operation.OriginalThing.ClassKind }, + TopContainer = new CopyReference { Iid = sourcepoco.TopContainer.Iid, ClassKind = sourcepoco.TopContainer.ClassKind }, IterationId = sourceIteration?.Iid }; var poco = operation.ModifiedThing.QuerySourceThing(); + if (poco.Container == null) { throw new InvalidOperationException("The container cannot be null."); } var targetIteration = poco.GetContainerOfType(); + var target = new CopyTarget { Container = new CopyReference { Iid = poco.Container.Iid, ClassKind = poco.Container.ClassKind }, diff --git a/CDP4ServicesDal/CdpServicesDal.cs b/CDP4ServicesDal/CdpServicesDal.cs index 05aec3413..9a2a3cd45 100644 --- a/CDP4ServicesDal/CdpServicesDal.cs +++ b/CDP4ServicesDal/CdpServicesDal.cs @@ -2,7 +2,7 @@ // // Copyright (c) 2015-2024 RHEA System S.A. // -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -27,7 +27,6 @@ namespace CDP4ServicesDal #if NETFRAMEWORK using System.ComponentModel.Composition; #endif - using System; using System.Collections.Generic; using System.Diagnostics; @@ -44,7 +43,6 @@ namespace CDP4ServicesDal using CDP4Common.CommonData; using CDP4Common.DTO; using CDP4Common.Extensions; - using CDP4DalCommon.Tasks; using CDP4Dal; using CDP4Dal.Composition; @@ -53,7 +51,10 @@ namespace CDP4ServicesDal using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4JsonSerializer; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; + + using CDP4DalJsonSerializer; using CDP4MessagePackSerializer; @@ -88,13 +89,21 @@ public class CdpServicesDal : Dal /// private HttpClient httpClient; + /// + /// Asserts that the MessagePack deserialization should be used or not + /// + private readonly bool isMessagePackSupported; + /// /// Initializes a new instance of the class. /// - public CdpServicesDal() + /// Asserts that the MessagePack deserialization should be used or not. Supported by default + public CdpServicesDal(bool isMessagePackSupported = true) { - this.Cdp4JsonSerializer = new Cdp4JsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Cdp4JsonSerializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); this.MessagePackSerializer = new MessagePackSerializer(); + + this.isMessagePackSupported = isMessagePackSupported; } /// @@ -103,7 +112,8 @@ public CdpServicesDal() /// /// The (injected) /// - public CdpServicesDal(HttpClient httpClient) : this() + /// Asserts that the MessagePack deserialization should be used or not. Supported by default + public CdpServicesDal(HttpClient httpClient, bool isMessagePackSupported = true) : this(isMessagePackSupported) { if (httpClient == null) { @@ -114,9 +124,9 @@ public CdpServicesDal(HttpClient httpClient) : this() } /// - /// Gets the + /// Gets the /// - public Cdp4JsonSerializer Cdp4JsonSerializer { get; private set; } + public Cdp4DalJsonSerializer Cdp4JsonSerializer { get; private set; } /// /// Gets the @@ -323,7 +333,7 @@ public override async Task Write(OperationContainer opera case ContentTypeKind.MESSAGEPACK: throw new NotSupportedException("Long running task not supported with MESSAGEPACK"); default: - throw new InvalidOperationException( $"ContentTypeKind {contentTypeKind} not supported"); + throw new InvalidOperationException($"ContentTypeKind {contentTypeKind} not supported"); } deserializationWatch.Stop(); @@ -716,7 +726,7 @@ public override async Task ReadCometTask(Guid id, CancellationToken c case ContentTypeKind.MESSAGEPACK: throw new NotSupportedException("Read CometTask by id not supported with MESSAGEPACK"); default: - throw new InvalidOperationException( $"ContentTypeKind {contentTypeKind} not supported"); + throw new InvalidOperationException($"ContentTypeKind {contentTypeKind} not supported"); } deserializationWatch.Stop(); @@ -777,7 +787,7 @@ public override async Task> ReadCometTasks(CancellationTo case ContentTypeKind.MESSAGEPACK: throw new NotSupportedException("Read all CometTask not supported with MESSAGEPACK"); default: - throw new InvalidOperationException( $"ContentTypeKind {contentTypeKind} not supported"); + throw new InvalidOperationException($"ContentTypeKind {contentTypeKind} not supported"); } deserializationWatch.Stop(); @@ -1051,7 +1061,12 @@ private HttpClient CreateHttpClient(Credentials credentials, HttpClient injected result.BaseAddress = credentials.Uri; result.DefaultRequestHeaders.Accept.Clear(); result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json")); - result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/msgpack")); + + if (this.isMessagePackSupported) + { + result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/msgpack")); + } + result.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(ASCIIEncoding.ASCII.GetBytes($"{credentials.UserName}:{credentials.Password}"))); result.DefaultRequestHeaders.Add(Headers.AcceptCdpVersion, Headers.AcceptCdpVersionValue); result.DefaultRequestHeaders.Add("User-Agent", "CDP4 (ECSS-E-TM-10-25 Annex C.2) CDPServicesDal"); @@ -1364,8 +1379,8 @@ private LongRunningTaskResult ExtractResultFromStream(Stream stream) var firstChar = (char)reader.Peek(); stream.Position = 0; - return firstChar == '[' - ? new LongRunningTaskResult(this.Cdp4JsonSerializer.Deserialize(stream)) + return firstChar == '[' + ? new LongRunningTaskResult(this.Cdp4JsonSerializer.Deserialize(stream)) : new LongRunningTaskResult(this.Cdp4JsonSerializer.Deserialize(stream)); } } diff --git a/CDP4ServicesDal/CopyOperationHandler.cs b/CDP4ServicesDal/CopyOperationHandler.cs index c54e612f2..4596d0fb3 100644 --- a/CDP4ServicesDal/CopyOperationHandler.cs +++ b/CDP4ServicesDal/CopyOperationHandler.cs @@ -1,26 +1,26 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal { @@ -31,12 +31,13 @@ namespace CDP4ServicesDal using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; - using CDP4Common.Helpers; using CDP4Dal; using CDP4Dal.Operations; using CDP4Dal.Permission; + using CDP4DalCommon.Protocol.Operations; + using Poco = CDP4Common.CommonData.Thing; /// @@ -55,7 +56,7 @@ internal class CopyOperationHandler private readonly ISession session; /// - /// A that map the original to the copied version + /// A that map the original to the copied version /// private Dictionary copyThingMap; @@ -95,6 +96,7 @@ public void ModifiedCopyOperation(OperationContainer operationContainer) var operationsToAdd = new List(); var copyOperationCount = operationContainer.Operations.Count(x => x.OperationKind.IsCopyOperation()); + if (copyOperationCount > 1) { // TODO: support this if needed @@ -102,6 +104,7 @@ public void ModifiedCopyOperation(OperationContainer operationContainer) } var copyOperation = operationContainer.Operations.SingleOrDefault(x => x.OperationKind.IsCopyOperation()); + if (copyOperation == null) { return; @@ -156,6 +159,7 @@ private void ComputeOperations(Operation copyOperation) // Add all contained objects this.copyableIds.AddRange(copyPermissionResult.CopyableThings.Select(c => c.Iid).ToList()); + if (this.copyableIds.Contains(originalPoco.Iid)) { var updatedIteration = copyPoco.GetContainerOfType(); @@ -164,6 +168,7 @@ private void ComputeOperations(Operation copyOperation) // modify the references to point to the copy thing this.ModifyReferences(); + if (copyOperation.OperationKind.IsCopyChangeOwnerOperation()) { this.ChangeOwner(updatedIteration); @@ -209,6 +214,7 @@ private void CreatePocoCopy(Poco poco, Iteration targetIteration) foreach (var containerList in poco.ContainerLists) { var updatedContainerList = new List(); + foreach (Poco containedPoco in containerList) { if (!this.copyableIds.Contains(containedPoco.Iid)) @@ -311,6 +317,7 @@ private void ModifyReferences(ElementUsage usage) private void ModifyReferences(Parameter parameter) { parameter.StateDependence = null; + if (parameter.Group == null) { return; @@ -319,6 +326,7 @@ private void ModifyReferences(Parameter parameter) // if the group cannot be copied, set to null Poco groupCopy; this.copyThingMap.TryGetValue(parameter.Group, out groupCopy); + parameter.Group = this.copyThingMap.TryGetValue(parameter.Group, out groupCopy) ? (ParameterGroup)groupCopy : null; @@ -338,6 +346,7 @@ private void ModifyReferences(ParameterGroup group) // if the group cannot be copied, set to null Poco groupCopy; this.copyThingMap.TryGetValue(group.ContainingGroup, out groupCopy); + group.ContainingGroup = this.copyThingMap.TryGetValue(group.ContainingGroup, out groupCopy) ? (ParameterGroup)groupCopy : null; @@ -361,12 +370,14 @@ private void ModifyReferences(ParameterOverride parameterOverride) private void ChangeOwner(Iteration iteration) { var activeDomain = this.session.OpenIterations.Single(x => x.Key.Iid == iteration.Iid).Value.Item1; + if (activeDomain == null) { throw new InvalidOperationException("The active domain is null. The copy operation cannot be performed."); } var ownedThings = this.copyThingMap.Values.OfType().ToList(); + foreach (var ownedThing in ownedThings) { // the owner of a subscription shall not be set to the active one @@ -379,4 +390,4 @@ private void ChangeOwner(Iteration iteration) } } } -} \ No newline at end of file +} diff --git a/CDP4ServicesDal/OperationModifier.cs b/CDP4ServicesDal/OperationModifier.cs index e47afbed0..c1c91970d 100644 --- a/CDP4ServicesDal/OperationModifier.cs +++ b/CDP4ServicesDal/OperationModifier.cs @@ -1,44 +1,42 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal { - using System; using System.Collections.Generic; using System.Linq; - using CDP4Common.CommonData; + using CDP4Common.EngineeringModelData; - using CDP4Common.Types; + using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using ActualFiniteState = CDP4Common.DTO.ActualFiniteState; - using ElementUsage = CDP4Common.DTO.ElementUsage; - using ParameterOverride = CDP4Common.DTO.ParameterOverride; - using ParameterSubscription = CDP4Common.DTO.ParameterSubscription; using PossibleFiniteStateList = CDP4Common.DTO.PossibleFiniteStateList; - + /// /// The purpose of the is to perform operations that /// are not performed directly by the server @@ -73,6 +71,7 @@ public void ModifyOperationContainer(OperationContainer operationContainer) if (operation.OperationKind == OperationKind.Update) { var possibleStateList = operation.ModifiedThing as PossibleFiniteStateList; + if (possibleStateList != null) { operationsToAdd.AddRange(this.ModifyActualStateKindOnDefaultPossibleStateUpdate(possibleStateList)); @@ -95,6 +94,7 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate { var operations = new List(); var defaultStateId = possibleFiniteStateList.DefaultState; + if (!defaultStateId.HasValue) { return operations; @@ -102,14 +102,15 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate // gets the actualList that uses the updated possible list var actualLists = this.session.Assembler.Cache.Select(x => x.Value) - .Select(x => x.Value) - .OfType() - .Where(x => x.PossibleFiniteStateList.Select(pl => pl.Iid).Contains(possibleFiniteStateList.Iid)) - .ToList(); + .Select(x => x.Value) + .OfType() + .Where(x => x.PossibleFiniteStateList.Select(pl => pl.Iid).Contains(possibleFiniteStateList.Iid)) + .ToList(); foreach (var actualFiniteStateList in actualLists) { var possibleLists = actualFiniteStateList.PossibleFiniteStateList.Where(x => x.Iid != possibleFiniteStateList.Iid).ToList(); + if (possibleLists.Any(x => x.DefaultState == null)) { // one of the possible list has no default state @@ -141,4 +142,4 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate return operations; } } -} \ No newline at end of file +} diff --git a/CDP4ServicesDal/ValueSetOperationCreator.cs b/CDP4ServicesDal/ValueSetOperationCreator.cs index da614ddbb..06beb83a4 100644 --- a/CDP4ServicesDal/ValueSetOperationCreator.cs +++ b/CDP4ServicesDal/ValueSetOperationCreator.cs @@ -1,38 +1,41 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4ServicesDal { using System; using System.Collections.Generic; using System.Linq; + using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; + using CDP4Dal; using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using Dto = CDP4Common.DTO; /// @@ -44,7 +47,7 @@ internal class ValueSetOperationCreator /// The associated /// private readonly ISession session; - + /// /// Initializes a new instance of the class /// @@ -70,6 +73,7 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume var dtolist = dtos.ToList(); var topContainer = dtolist.SingleOrDefault(x => x is Dto.TopContainer); + if (topContainer == null) { throw new InvalidOperationException("No Top container were found in the returned list of dtos."); @@ -78,9 +82,10 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume // Gets the parameter base which value set shall be updated var copyParameterBases = dtolist.OfType().ToList(); var copyParameterBasesIds = copyParameterBases.Select(p => p.Iid).ToList(); + var valuesets = dtolist.Where(dto => dto.ClassKind == ClassKind.ParameterValueSet || - dto.ClassKind == ClassKind.ParameterSubscriptionValueSet || - dto.ClassKind == ClassKind.ParameterOverrideValueSet).ToList(); + dto.ClassKind == ClassKind.ParameterSubscriptionValueSet || + dto.ClassKind == ClassKind.ParameterOverrideValueSet).ToList(); this.ComputeRoutes(valuesets, dtolist); var valueSetsClones = valuesets.Select(dto => dto.DeepClone()).ToList(); @@ -98,6 +103,7 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume // value sets to update var copyValueSets = valueSetsClones.Where(x => copyDto.ValueSets.Contains(x.Iid)).ToList(); var defaultValueSet = this.GetDefaultValueSet(originalParameter); + if (defaultValueSet == null) { continue; @@ -107,6 +113,7 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume } var operationContainer = new OperationContainer(context, topContainer.RevisionNumber); + foreach (var valueSetsClone in valueSetsClones) { var valuesetToUpdate = valuesets.Single(x => x.Iid == valueSetsClone.Iid); @@ -203,4 +210,4 @@ private void SetValueSetValues(Dto.ParameterSubscriptionValueSet valueSet, Param valueSet.ValueSwitch = originalValueSet.ValueSwitch; } } -} \ No newline at end of file +} diff --git a/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj b/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj index 81eca8dea..31b1156fd 100644 --- a/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj +++ b/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj @@ -1,4 +1,4 @@ - + netstandard2.0 diff --git a/CDP4ServicesMessaging/Serializers/Json/Cdp4MessageSerializer.cs b/CDP4ServicesMessaging/Serializers/Json/Cdp4MessageSerializer.cs index 93581f856..7504aba46 100644 --- a/CDP4ServicesMessaging/Serializers/Json/Cdp4MessageSerializer.cs +++ b/CDP4ServicesMessaging/Serializers/Json/Cdp4MessageSerializer.cs @@ -1,21 +1,21 @@ // ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2023 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Antoine Théate, Nathanael Smiechowski -// -// This file is part of COMET-SDK Community Edition -// -// The CDP4-COMET-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -27,13 +27,12 @@ namespace CDP4ServicesMessaging.Serializers.Json using System; using System.Diagnostics; using System.IO; - + using System.Text.Json; + using CDP4Common.MetaInfo; using CDP4JsonSerializer; - using Newtonsoft.Json; - using NLog; /// @@ -58,7 +57,7 @@ public Cdp4MessageSerializer() /// /// The public Cdp4MessageSerializer(IMetaDataProvider metaInfoProvider) : base(metaInfoProvider, metaInfoProvider.GetMaxSupportedModelVersion()) - { + { } /// @@ -70,27 +69,22 @@ public Cdp4MessageSerializer(IMetaDataProvider metaInfoProvider) : base(metaInfo public ReadOnlyMemory Serialize(T message) { var sw = Stopwatch.StartNew(); - var serializer = this.CreateJsonSerializer(); // Use a MemoryStream to store the serialized data using var memoryStream = new MemoryStream(); - Logger.Trace("initializing JsonTextWriter"); - using var jsonWriter = new JsonTextWriter(new StreamWriter(memoryStream)); - Logger.Trace("Serialize to JsonTextWriter"); - serializer.Serialize(jsonWriter, message); - jsonWriter.Flush(); + JsonSerializer.Serialize(memoryStream, message, this.JsonSerializerOptions); // Get the ReadOnlyMemory from the MemoryStream var serializedMessage = new ReadOnlyMemory(memoryStream.ToArray()); sw.Stop(); Logger.Debug("SerializeThingsChangedMessage finished in {0} [ms]", sw.ElapsedMilliseconds); - + return serializedMessage; } - + /// /// Deserializes a message of type from the specified . /// diff --git a/CDP4WspDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs b/CDP4WspDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs index 075e19824..037c9cb96 100644 --- a/CDP4WspDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/CopyOperationHandlerTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -36,6 +36,8 @@ namespace CDP4WspDal.Tests using CDP4Dal.Operations; using CDP4Dal.Permission; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4WspDal.NetCore.Tests/OperationModifierTestFixture.cs b/CDP4WspDal.NetCore.Tests/OperationModifierTestFixture.cs index 66b06dbd7..d8376f1f3 100644 --- a/CDP4WspDal.NetCore.Tests/OperationModifierTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/OperationModifierTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -34,6 +34,8 @@ namespace CDP4WspDal.Tests using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4WspDal.NetCore.Tests/Operations/WSPPostOperationTestFixture.cs b/CDP4WspDal.NetCore.Tests/Operations/WSPPostOperationTestFixture.cs index 61510f108..5c1bd2b3f 100644 --- a/CDP4WspDal.NetCore.Tests/Operations/WSPPostOperationTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/Operations/WSPPostOperationTestFixture.cs @@ -1,40 +1,38 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests.Operations { using System; using System.Collections; - using System.Collections.Generic; using System.Linq; + using CDP4Common.DTO; - using CDP4Common.MetaInfo; + using CDP4Common.MetaInfo; using CDP4Common.Types; - using CDP4Dal.Operations; - using CDP4WspDal; + + using CDP4DalCommon.Protocol.Operations; using NUnit.Framework; @@ -101,7 +99,7 @@ public void VerifyThatExceptionIsThrownWhenModifiedThingIsNotProvided() { var simpleUnit = new SimpleUnit(Guid.NewGuid(), 1); var operation = new Operation(simpleUnit, null, OperationKind.Delete); - Assert.Throws(() => this.wspPostOperation.ConstructFromOperation(operation)) ; + Assert.Throws(() => this.wspPostOperation.ConstructFromOperation(operation)); } [Test] diff --git a/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs b/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs index 2a0bd0d22..1a41f72a7 100644 --- a/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs @@ -1,61 +1,70 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Yevhen Ikonnykov -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { using System; using System.Collections.Generic; using System.IO; + using CDP4Common; + using CDP4Common.CommonData; using CDP4Common.Dto; + using CDP4Common.DTO; using CDP4Common.MetaInfo; - using CDP4JsonSerializer; + using CDP4Common.Types; + using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer; + using CDP4WspDal.Tests.Helper; - using Newtonsoft.Json; + using NUnit.Framework; - using CDP4Common.DTO; - using CDP4Common.CommonData; - using CDP4Common.Types; + using File = System.IO.File; + using Thing = CDP4Common.DTO.Thing; [TestFixture] public class PostOperationTestFixture { - private Cdp4JsonSerializer serializer; + private Cdp4DalJsonSerializer serializer; [SetUp] public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4JsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0), true); } [Test] public void Verify_that_deserialization_of_Post_Operation_does_not_throw_an_exception() { var response = File.ReadAllText(Path.Combine(TestContext.CurrentContext.TestDirectory, "TestData/PostOperation.json")); + using (var stream = StreamHelper.GenerateStreamFromString(response)) { Assert.DoesNotThrow(() => this.serializer.Deserialize(stream)); @@ -93,7 +102,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( var fileRevision = new FileRevision(fileRevisionIid, 0); fileRevision.Name = "testfile"; fileRevision.ContentHash = "F73747371CFD9473C19A0A7F99BCAB008474C4CA"; - fileRevision.FileType.Add(new OrderedItem() { K = 1, V = fileTypeIid }); + fileRevision.FileType.Add(new OrderedItem { K = 1, V = fileTypeIid }); fileRevision.Creator = participantIid; fileRevision.AddContainer(ClassKind.File, fileIid); fileRevision.AddContainer(ClassKind.DomainFileStore, domainFileStoreIid); @@ -101,7 +110,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( fileRevision.AddContainer(ClassKind.EngineeringModel, engineeringModelIid); var context = $"/EngineeringModel/{engineeringModelIid}/iteration/{iterationIid}"; - var operationContainer = new OperationContainer(context, null); + var operationContainer = new OperationContainer(context); var updateCommonFileStoreOperation = new Operation(originalDomainFileStore, modifiedDomainFileStore, OperationKind.Update); operationContainer.AddOperation(updateCommonFileStoreOperation); @@ -131,34 +140,30 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( private class TestPostOperation : PostOperation { - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } - /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] - public override List Create { get; set; } + public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_copy")] public override List Copy { get; set; } + + public override void ConstructFromOperation(Operation operation) + { + throw new NotImplementedException(); + } } } } diff --git a/CDP4WspDal.NetCore.Tests/WSPDalTestFixture.cs b/CDP4WspDal.NetCore.Tests/WSPDalTestFixture.cs index 19f356f88..71c71bc46 100644 --- a/CDP4WspDal.NetCore.Tests/WSPDalTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/WSPDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -45,6 +45,8 @@ namespace CDP4WspDal.Tests using CDP4Dal.DAL.ECSS1025AnnexC; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; /// diff --git a/CDP4WspDal.Tests/CopyOperationHandlerTestFixture.cs b/CDP4WspDal.Tests/CopyOperationHandlerTestFixture.cs index f5b4c39e9..3050dcd75 100644 --- a/CDP4WspDal.Tests/CopyOperationHandlerTestFixture.cs +++ b/CDP4WspDal.Tests/CopyOperationHandlerTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -36,6 +36,8 @@ namespace CDP4WspDal.Tests using CDP4Dal.Operations; using CDP4Dal.Permission; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4WspDal.Tests/OperationModifierTestFixture.cs b/CDP4WspDal.Tests/OperationModifierTestFixture.cs index 355d6e127..d8376f1f3 100644 --- a/CDP4WspDal.Tests/OperationModifierTestFixture.cs +++ b/CDP4WspDal.Tests/OperationModifierTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- -// +// ------------------------------------------------------------------------------------------------------------------------------- +// // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -34,6 +34,8 @@ namespace CDP4WspDal.Tests using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using Moq; using NUnit.Framework; diff --git a/CDP4WspDal.Tests/Operations/WSPPostOperationTestFixture.cs b/CDP4WspDal.Tests/Operations/WSPPostOperationTestFixture.cs index 61510f108..5c1bd2b3f 100644 --- a/CDP4WspDal.Tests/Operations/WSPPostOperationTestFixture.cs +++ b/CDP4WspDal.Tests/Operations/WSPPostOperationTestFixture.cs @@ -1,40 +1,38 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests.Operations { using System; using System.Collections; - using System.Collections.Generic; using System.Linq; + using CDP4Common.DTO; - using CDP4Common.MetaInfo; + using CDP4Common.MetaInfo; using CDP4Common.Types; - using CDP4Dal.Operations; - using CDP4WspDal; + + using CDP4DalCommon.Protocol.Operations; using NUnit.Framework; @@ -101,7 +99,7 @@ public void VerifyThatExceptionIsThrownWhenModifiedThingIsNotProvided() { var simpleUnit = new SimpleUnit(Guid.NewGuid(), 1); var operation = new Operation(simpleUnit, null, OperationKind.Delete); - Assert.Throws(() => this.wspPostOperation.ConstructFromOperation(operation)) ; + Assert.Throws(() => this.wspPostOperation.ConstructFromOperation(operation)); } [Test] diff --git a/CDP4WspDal.Tests/PostOperationTestFixture.cs b/CDP4WspDal.Tests/PostOperationTestFixture.cs index 64a169578..1a41f72a7 100644 --- a/CDP4WspDal.Tests/PostOperationTestFixture.cs +++ b/CDP4WspDal.Tests/PostOperationTestFixture.cs @@ -1,61 +1,70 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexander van Delft, Yevhen Ikonnykov -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { using System; using System.Collections.Generic; using System.IO; + using CDP4Common; + using CDP4Common.CommonData; using CDP4Common.Dto; using CDP4Common.DTO; using CDP4Common.MetaInfo; - using CDP4JsonSerializer; + using CDP4Common.Types; + using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + + using CDP4DalJsonSerializer; + using CDP4WspDal.Tests.Helper; - using Newtonsoft.Json; + using NUnit.Framework; - using CDP4Common.Types; + using File = System.IO.File; - using CDP4Common.CommonData; + using Thing = CDP4Common.DTO.Thing; [TestFixture] public class PostOperationTestFixture { - private Cdp4JsonSerializer serializer; + private Cdp4DalJsonSerializer serializer; [SetUp] public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4JsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0), true); } [Test] public void Verify_that_deserialization_of_Post_Operation_does_not_throw_an_exception() { var response = File.ReadAllText(Path.Combine(TestContext.CurrentContext.TestDirectory, "TestData/PostOperation.json")); + using (var stream = StreamHelper.GenerateStreamFromString(response)) { Assert.DoesNotThrow(() => this.serializer.Deserialize(stream)); @@ -93,7 +102,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( var fileRevision = new FileRevision(fileRevisionIid, 0); fileRevision.Name = "testfile"; fileRevision.ContentHash = "F73747371CFD9473C19A0A7F99BCAB008474C4CA"; - fileRevision.FileType.Add(new OrderedItem() { K = 1, V = fileTypeIid }); + fileRevision.FileType.Add(new OrderedItem { K = 1, V = fileTypeIid }); fileRevision.Creator = participantIid; fileRevision.AddContainer(ClassKind.File, fileIid); fileRevision.AddContainer(ClassKind.DomainFileStore, domainFileStoreIid); @@ -101,7 +110,7 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( fileRevision.AddContainer(ClassKind.EngineeringModel, engineeringModelIid); var context = $"/EngineeringModel/{engineeringModelIid}/iteration/{iterationIid}"; - var operationContainer = new OperationContainer(context, null); + var operationContainer = new OperationContainer(context); var updateCommonFileStoreOperation = new Operation(originalDomainFileStore, modifiedDomainFileStore, OperationKind.Update); operationContainer.AddOperation(updateCommonFileStoreOperation); @@ -128,36 +137,33 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( Assert.AreEqual(expected, streamReader.ReadToEnd()); } } + private class TestPostOperation : PostOperation { - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } - /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] - public override List Create { get; set; } + public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_copy")] public override List Copy { get; set; } + + public override void ConstructFromOperation(Operation operation) + { + throw new NotImplementedException(); + } } } } diff --git a/CDP4WspDal.Tests/WSPDalTestFixture.cs b/CDP4WspDal.Tests/WSPDalTestFixture.cs index 025de3d3c..a643d9751 100644 --- a/CDP4WspDal.Tests/WSPDalTestFixture.cs +++ b/CDP4WspDal.Tests/WSPDalTestFixture.cs @@ -1,8 +1,8 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // // Copyright (c) 2015-2024 RHEA System S.A. -// -// Author: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar // // This file is part of CDP4-COMET SDK Community Edition // @@ -20,7 +20,7 @@ // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal.Tests { @@ -45,6 +45,8 @@ namespace CDP4WspDal.Tests using CDP4Dal.DAL.ECSS1025AnnexC; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using NUnit.Framework; /// diff --git a/CDP4WspDal/CDP4WspDal.csproj b/CDP4WspDal/CDP4WspDal.csproj index ecb36ab64..62ffa7c86 100644 --- a/CDP4WspDal/CDP4WspDal.csproj +++ b/CDP4WspDal/CDP4WspDal.csproj @@ -41,7 +41,7 @@ - + diff --git a/CDP4WspDal/CopyOperationHandler.cs b/CDP4WspDal/CopyOperationHandler.cs index c9190b976..2b66111c2 100644 --- a/CDP4WspDal/CopyOperationHandler.cs +++ b/CDP4WspDal/CopyOperationHandler.cs @@ -1,28 +1,26 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal { @@ -30,11 +28,16 @@ namespace CDP4WspDal using System.Collections.Generic; using System.Linq; using System.Reflection; + using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; + using CDP4Dal; using CDP4Dal.Operations; using CDP4Dal.Permission; + + using CDP4DalCommon.Protocol.Operations; + using Poco = CDP4Common.CommonData.Thing; /// @@ -53,7 +56,7 @@ internal class CopyOperationHandler private readonly ISession session; /// - /// A that map the original to the copied version + /// A that map the original to the copied version /// private Dictionary copyThingMap; @@ -82,7 +85,7 @@ public CopyOperationHandler(ISession session) public IReadOnlyDictionary CopyThingMap { get { return this.copyThingMap; } - } + } /// /// Modify the if it contains copy @@ -93,6 +96,7 @@ public void ModifiedCopyOperation(OperationContainer operationContainer) var operationsToAdd = new List(); var copyOperationCount = operationContainer.Operations.Count(x => x.OperationKind.IsCopyOperation()); + if (copyOperationCount > 1) { // TODO: support this if needed @@ -100,6 +104,7 @@ public void ModifiedCopyOperation(OperationContainer operationContainer) } var copyOperation = operationContainer.Operations.SingleOrDefault(x => x.OperationKind.IsCopyOperation()); + if (copyOperation == null) { return; @@ -140,7 +145,7 @@ private void ComputeOperations(Operation copyOperation) var originalDto = copyOperation.OriginalThing; var originalPoco = originalDto.QuerySourceThing(); - + if (copyPoco.TopContainer.ClassKind != ClassKind.EngineeringModel) { throw new InvalidOperationException("The copy operation on WSP is only implemented for things contained by EngineeringModel."); @@ -154,6 +159,7 @@ private void ComputeOperations(Operation copyOperation) // Add all contained objects this.copyableIds.AddRange(copyPermissionResult.CopyableThings.Select(c => c.Iid).ToList()); + if (this.copyableIds.Contains(originalPoco.Iid)) { var updatedIteration = copyPoco.GetContainerOfType(); @@ -162,6 +168,7 @@ private void ComputeOperations(Operation copyOperation) // modify the references to point to the copy thing this.ModifyReferences(); + if (copyOperation.OperationKind.IsCopyChangeOwnerOperation()) { this.ChangeOwner(updatedIteration); @@ -207,6 +214,7 @@ private void CreatePocoCopy(Poco poco, Iteration targetIteration) foreach (var containerList in poco.ContainerLists) { var updatedContainerList = new List(); + foreach (Poco containedPoco in containerList) { if (!this.copyableIds.Contains(containedPoco.Iid)) @@ -265,6 +273,7 @@ private void CreateOperations() } #region Modify References + /// /// Modify the references for a and all its contained elements /// @@ -310,6 +319,7 @@ private void ModifyReferences(ElementUsage usage) private void ModifyReferences(Parameter parameter) { parameter.StateDependence = null; + if (parameter.Group == null) { return; @@ -318,6 +328,7 @@ private void ModifyReferences(Parameter parameter) // if the group cannot be copied, set to null Poco groupCopy; this.copyThingMap.TryGetValue(parameter.Group, out groupCopy); + parameter.Group = this.copyThingMap.TryGetValue(parameter.Group, out groupCopy) ? (ParameterGroup)groupCopy : null; @@ -337,6 +348,7 @@ private void ModifyReferences(ParameterGroup group) // if the group cannot be copied, set to null Poco groupCopy; this.copyThingMap.TryGetValue(group.ContainingGroup, out groupCopy); + group.ContainingGroup = this.copyThingMap.TryGetValue(group.ContainingGroup, out groupCopy) ? (ParameterGroup)groupCopy : null; @@ -352,6 +364,7 @@ private void ModifyReferences(ParameterOverride parameterOverride) var copy = (Parameter)this.copyThingMap[parameterOverride.Parameter]; parameterOverride.Parameter = copy; } + #endregion /// @@ -361,12 +374,14 @@ private void ModifyReferences(ParameterOverride parameterOverride) private void ChangeOwner(Iteration iteration) { var activeDomain = this.session.OpenIterations.Single(x => x.Key.Iid == iteration.Iid).Value.Item1; + if (activeDomain == null) { throw new InvalidOperationException("The active domain is null. The copy operation cannot be performed."); } var ownedThings = this.copyThingMap.Values.OfType().ToList(); + foreach (var ownedThing in ownedThings) { // the owner of a subscription shall not be set to the active one @@ -379,4 +394,4 @@ private void ChangeOwner(Iteration iteration) } } } -} \ No newline at end of file +} diff --git a/CDP4WspDal/OperationModifier.cs b/CDP4WspDal/OperationModifier.cs index 03629343b..52cea9c70 100644 --- a/CDP4WspDal/OperationModifier.cs +++ b/CDP4WspDal/OperationModifier.cs @@ -1,38 +1,42 @@ -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal { using System; using System.Collections.Generic; using System.Linq; + using CDP4Common.CommonData; - using CDP4Common.EngineeringModelData; + using CDP4Common.EngineeringModelData; using CDP4Common.Types; + using CDP4Dal; using CDP4Dal.Operations; + using CDP4DalCommon.Protocol.Operations; + using ActualFiniteState = CDP4Common.DTO.ActualFiniteState; using ElementUsage = CDP4Common.DTO.ElementUsage; using ParameterOverride = CDP4Common.DTO.ParameterOverride; @@ -72,6 +76,7 @@ public void ModifyOperationContainer(OperationContainer operationContainer) if (operation.OperationKind == OperationKind.Create) { var parameterOverride = operation.ModifiedThing as ParameterOverride; + if (parameterOverride != null) { operationsToAdd.AddRange(this.AddParameterSubscriptionCreateOperation(operationContainer, parameterOverride)); @@ -80,6 +85,7 @@ public void ModifyOperationContainer(OperationContainer operationContainer) else if (operation.OperationKind == OperationKind.Update) { var possibleStateList = operation.ModifiedThing as PossibleFiniteStateList; + if (possibleStateList != null) { operationsToAdd.AddRange(this.ModifyActualStateKindOnDefaultPossibleStateUpdate(possibleStateList)); @@ -90,7 +96,7 @@ public void ModifyOperationContainer(OperationContainer operationContainer) foreach (var operation in operationsToAdd) { operationContainer.AddOperation(operation); - } + } } /// @@ -104,12 +110,14 @@ private IEnumerable AddParameterSubscriptionCreateOperation(Operation var parameterId = parameterOverride.Parameter; Lazy lazyParameter; var operations = new List(); + if (!this.session.Assembler.Cache.TryGetValue(new CacheKey(parameterId, parameterOverride.IterationContainerId), out lazyParameter)) { return operations; } - + var parameter = (Parameter)lazyParameter.Value; + foreach (var subscription in parameter.ParameterSubscription.Where(x => x.Owner.Iid != parameterOverride.Owner)) { var parameterSubscription = new ParameterSubscription @@ -123,13 +131,14 @@ private IEnumerable AddParameterSubscriptionCreateOperation(Operation operationContainer.Operations.Select(x => x.ModifiedThing) .OfType() .SingleOrDefault(x => x.ParameterOverride.Contains(parameterOverride.Iid)); - + if (elementUsageContainer == null) { continue; } Lazy lazyElementUsageContainer; + if (!this.session.Assembler.Cache.TryGetValue(new CacheKey(elementUsageContainer.Iid, elementUsageContainer.IterationContainerId), out lazyElementUsageContainer)) { continue; @@ -166,6 +175,7 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate { var operations = new List(); var defaultStateId = possibleFiniteStateList.DefaultState; + if (!defaultStateId.HasValue) { return operations; @@ -173,14 +183,15 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate // gets the actualList that uses the updated possible list var actualLists = this.session.Assembler.Cache.Select(x => x.Value) - .Select(x => x.Value) - .OfType() - .Where(x => x.PossibleFiniteStateList.Select(pl => pl.Iid).Contains(possibleFiniteStateList.Iid)) - .ToList(); + .Select(x => x.Value) + .OfType() + .Where(x => x.PossibleFiniteStateList.Select(pl => pl.Iid).Contains(possibleFiniteStateList.Iid)) + .ToList(); foreach (var actualFiniteStateList in actualLists) { var possibleLists = actualFiniteStateList.PossibleFiniteStateList.Where(x => x.Iid != possibleFiniteStateList.Iid).ToList(); + if (possibleLists.Any(x => x.DefaultState == null)) { // one of the possible list has no default state @@ -212,4 +223,4 @@ private IEnumerable ModifyActualStateKindOnDefaultPossibleStateUpdate return operations; } } -} \ No newline at end of file +} diff --git a/CDP4WspDal/ValueSetOperationCreator.cs b/CDP4WspDal/ValueSetOperationCreator.cs index a4e49ccd3..9aa9f59db 100644 --- a/CDP4WspDal/ValueSetOperationCreator.cs +++ b/CDP4WspDal/ValueSetOperationCreator.cs @@ -1,38 +1,41 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal { using System; using System.Collections.Generic; using System.Linq; + using CDP4Common.CommonData; - using CDP4Common.EngineeringModelData; + using CDP4Common.EngineeringModelData; + using CDP4Dal; using CDP4Dal.Operations; + + using CDP4DalCommon.Protocol.Operations; + using Dto = CDP4Common.DTO; /// @@ -44,7 +47,7 @@ internal class ValueSetOperationCreator /// The associated /// private readonly ISession session; - + /// /// Initializes a new instance of the class /// @@ -70,6 +73,7 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume var dtolist = dtos.ToList(); var topContainer = dtolist.SingleOrDefault(x => x is Dto.TopContainer); + if (topContainer == null) { throw new InvalidOperationException("No Top container were found in the returned list of dtos."); @@ -78,9 +82,10 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume // Gets the parameter base which value set shall be updated var copyParameterBases = dtolist.OfType().ToList(); var copyParameterBasesIds = copyParameterBases.Select(p => p.Iid).ToList(); - var valuesets = dtolist.Where(dto => dto.ClassKind == ClassKind.ParameterValueSet || - dto.ClassKind == ClassKind.ParameterSubscriptionValueSet || - dto.ClassKind == ClassKind.ParameterOverrideValueSet).ToList(); + + var valuesets = dtolist.Where(dto => dto.ClassKind == ClassKind.ParameterValueSet || + dto.ClassKind == ClassKind.ParameterSubscriptionValueSet || + dto.ClassKind == ClassKind.ParameterOverrideValueSet).ToList(); this.ComputeRoutes(valuesets, dtolist); var valueSetsClones = valuesets.Select(dto => dto.DeepClone()).ToList(); @@ -98,6 +103,7 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume // value sets to update var copyValueSets = valueSetsClones.Where(x => copyDto.ValueSets.Contains(x.Iid)).ToList(); var defaultValueSet = this.GetDefaultValueSet(originalParameter); + if (defaultValueSet == null) { continue; @@ -105,8 +111,9 @@ public OperationContainer CreateValueSetsUpdateOperations(string context, IEnume this.SetValueSetValues(copyValueSets, defaultValueSet); } - + var operationContainer = new OperationContainer(context, topContainer.RevisionNumber); + foreach (var valueSetsClone in valueSetsClones) { var valuesetToUpdate = valuesets.Single(x => x.Iid == valueSetsClone.Iid); @@ -203,4 +210,4 @@ private void SetValueSetValues(Dto.ParameterSubscriptionValueSet valueSet, Param valueSet.ValueSwitch = originalValueSet.ValueSwitch; } } -} \ No newline at end of file +} diff --git a/CDP4WspDal/WSPDal.cs b/CDP4WspDal/WSPDal.cs index 8c80db5c1..fe475eff7 100644 --- a/CDP4WspDal/WSPDal.cs +++ b/CDP4WspDal/WSPDal.cs @@ -1,21 +1,21 @@ // ------------------------------------------------------------------------------------------------------------------------------- -// -// Copyright (c) 2015-2021 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou, Alexandervan Delft, Nathanael Smiechowski, Ahmed Abulwafa Ahmed -// -// This file is part of COMET-SDK Community Edition -// -// The COMET-SDK Community Edition is free software; you can redistribute it and/or +// +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The COMET-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -27,7 +27,6 @@ namespace CDP4WspDal #if NETFRAMEWORK using System.ComponentModel.Composition; #endif - using System; using System.Collections.Generic; using System.Diagnostics; @@ -50,10 +49,11 @@ namespace CDP4WspDal using CDP4Dal.Exceptions; using CDP4Dal.Operations; - using CDP4DalCommon.Tasks; + using CDP4DalCommon.Protocol.Operations; + using CDP4DalCommon.Protocol.Tasks; + + using CDP4DalJsonSerializer; - using CDP4JsonSerializer; - using NLog; using EngineeringModelSetup = CDP4Common.SiteDirectoryData.EngineeringModelSetup; @@ -83,13 +83,13 @@ public class WspDal : Dal /// public WspDal() { - this.Serializer = new Cdp4JsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion, true); } /// - /// Gets or sets the + /// Gets or sets the /// - public Cdp4JsonSerializer Serializer { get; private set; } + public Cdp4DalJsonSerializer Serializer { get; private set; } /// /// Gets the value indicating whether this is read only @@ -140,18 +140,19 @@ public override async Task> Write(OperationContainer operatio modifier.ModifyOperationContainer(operationContainer); var invalidOperationKind = operationContainer.Operations.Any(operation => operation.OperationKind == OperationKind.Move || OperationKindExtensions.IsCopyOperation(operation.OperationKind)); + if (invalidOperationKind) { throw new InvalidOperationKindException("The WSP DAL does not support Copy or Move operations"); } - + var result = new List(); if (files != null && files.Any()) { this.OperationContainerFileVerification(operationContainer, files); } - + var attribute = new QueryAttributes { RevisionNumber = operationContainer.TopContainerRevisionNumber @@ -180,12 +181,13 @@ public override async Task> Write(OperationContainer operatio Logger.Error(msg); throw new DalWriteException(msg); } - + using (var resultStream = await httpResponseMessage.Content.ReadAsStreamAsync()) { result.AddRange(this.Serializer.Deserialize(resultStream)); Guid iterationId; + if (this.TryExtractIterationIdfromUri(httpResponseMessage.RequestMessage.RequestUri, out iterationId)) { this.SetIterationContainer(result, iterationId); @@ -204,6 +206,7 @@ public override async Task> Write(OperationContainer operatio foreach (var valueSetDto in valueSetResult) { var index = result.FindIndex(x => x.Iid == valueSetDto.Iid); + if (index >= 0) { result[index] = valueSetDto; @@ -282,6 +285,7 @@ public override async Task> Read(CDP4Common.DTO.Iteration ite // Get the RequiredRdl to load var siteDirectory = this.Session.Assembler.RetrieveSiteDirectory(); var iterationSetup = siteDirectory.Model.SelectMany(mod => mod.IterationSetup).SingleOrDefault(it => it.IterationIid == iteration.Iid); + if (iterationSetup == null) { throw new InvalidOperationException("The Iteration to open does not have any associated IterationSetup."); @@ -401,12 +405,13 @@ public override async Task> Read(T thing, CancellationToke Logger.Error(msg); throw new DalReadException(msg); } - + using (var resultStream = await httpResponseMessage.Content.ReadAsStreamAsync()) { var returned = this.Serializer.Deserialize(resultStream); Guid iterationId; + if (this.TryExtractIterationIdfromUri(httpResponseMessage.RequestMessage.RequestUri, out iterationId)) { this.SetIterationContainer(returned, iterationId); @@ -419,7 +424,7 @@ public override async Task> Read(T thing, CancellationToke } } } - + /// /// Reads the identified by the provided /// @@ -529,9 +534,9 @@ public override async Task> Open(Credentials credentials, Can var openToken = CDP4Common.Helpers.TokenGenerator.GenerateRandomToken(); this.httpClient = this.CreateHttpClient(credentials); - + var watch = Stopwatch.StartNew(); - + var uriBuilder = this.GetUriBuilder(credentials.Uri, ref resourcePath); Logger.Debug("Resource Path {0}: {1}", openToken, resourcePath); @@ -543,7 +548,7 @@ public override async Task> Open(Credentials credentials, Can { Logger.Info("The ECSS-E-TM-10-25A Annex C Services responded in {0} [ms] to Open {1}", requestsw.ElapsedMilliseconds, openToken); requestsw.Stop(); - + if (httpResponseMessage.StatusCode != HttpStatusCode.OK) { var msg = $"The data-source replied with code {httpResponseMessage.StatusCode}: {httpResponseMessage.ReasonPhrase}"; @@ -553,7 +558,7 @@ public override async Task> Open(Credentials credentials, Can watch.Stop(); Logger.Info("WSP DAL Open {0} completed in {1} [ms]", openToken, watch.ElapsedMilliseconds); - + watch = Stopwatch.StartNew(); using (var resultStream = await httpResponseMessage.Content.ReadAsStreamAsync()) @@ -564,6 +569,7 @@ public override async Task> Open(Credentials credentials, Can Logger.Info("JSON Deserializer completed in {0} [ms]", watch.ElapsedMilliseconds); var returnedPerson = returned.OfType().SingleOrDefault(x => x.ShortName == credentials.UserName); + if (returnedPerson == null) { throw new InvalidOperationException("User not found."); @@ -709,6 +715,7 @@ internal void ConstructPostRequestBodyStream(string token, OperationContainer op { outputStream.CopyTo(memoryStream); memoryStream.Position = 0; + using (var streamReader = new StreamReader(memoryStream)) { var postBody = streamReader.ReadToEnd(); @@ -763,6 +770,7 @@ public override bool IsValidUri(string uri) try { var validUriAssertion = new Uri(uri); + if (!(validUriAssertion.Scheme == Uri.UriSchemeHttp || validUriAssertion.Scheme == Uri.UriSchemeHttps)) { return false; @@ -814,6 +822,6 @@ private IQueryAttributes GetIUriQueryAttribute(bool includeReferenceData = false Extent = ExtentQueryAttribute.deep, IncludeAllContainers = true }; - } + } } } diff --git a/CDP4WspDal/WSPPostOperation.cs b/CDP4WspDal/WSPPostOperation.cs index 5c403befe..8888b2b27 100644 --- a/CDP4WspDal/WSPPostOperation.cs +++ b/CDP4WspDal/WSPPostOperation.cs @@ -1,28 +1,26 @@ -#region Copyright -// -------------------------------------------------------------------------------------------------------------------- +// ------------------------------------------------------------------------------------------------------------------------------- // -// Copyright (c) 2015-2019 RHEA System S.A. -// -// Author: Sam Gerené, Merlin Bieze, Alex Vorobiev, Naron Phou -// -// This file is part of CDP4-SDK Community Edition -// -// The CDP4-SDK Community Edition is free software; you can redistribute it and/or +// Copyright (c) 2015-2024 RHEA System S.A. +// +// Authors: Sam Gerené, Alex Vorobiev, Alexander van Delft, Nathanael Smiechowski, Antoine Théate, Omar Elebiary, Jaime Bernar +// +// This file is part of CDP4-COMET SDK Community Edition +// +// The CDP4-COMET SDK Community Edition is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 3 of the License, or (at your option) any later version. -// -// The CDP4-SDK Community Edition is distributed in the hope that it will be useful, +// +// The CDP4-COMET SDK Community Edition is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. -// +// // You should have received a copy of the GNU Lesser General Public License // along with this program; if not, write to the Free Software Foundation, // Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// -------------------------------------------------------------------------------------------------------------------- -#endregion +// ------------------------------------------------------------------------------------------------------------------------------- namespace CDP4WspDal { @@ -30,15 +28,16 @@ namespace CDP4WspDal using System.Collections; using System.Collections.Generic; using System.Linq; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.Dto; using CDP4Common.MetaInfo; using CDP4Common.SiteDirectoryData; using CDP4Common.Types; - using CDP4Dal.Operations; - using Newtonsoft.Json; - using DomainOfExpertise = CDP4Common.DTO.DomainOfExpertise; + + using CDP4DalCommon.Protocol.Operations; + using Thing = CDP4Common.DTO.Thing; /// @@ -63,25 +62,21 @@ public WspPostOperation(IMetaDataProvider metaDataProvider) /// /// Gets or sets the collection of DTOs to delete. /// - [JsonProperty("_delete")] public override List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - [JsonProperty("_create")] public override List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - [JsonProperty("_update")] public override List Update { get; set; } /// /// Gets or sets the collection of DTOs to copy. /// - [JsonIgnore] public override List Copy { get; set; } /// @@ -139,6 +134,7 @@ private void ResolveUpdate(Operation operation) foreach (var key in original.Keys) { var originalIenumerable = original[key] as IEnumerable; + if (originalIenumerable != null && originalIenumerable.GetType().IsGenericType) { var modifiedIenumerable = (IEnumerable)modifiedFull[key]; @@ -162,6 +158,7 @@ private void ResolveUpdate(Operation operation) List modifiedProperty; var genericTypeArgument = original[key].GetType().GenericTypeArguments[0]; + if (genericTypeArgument == typeof(Guid) || genericTypeArgument == typeof(ClassKind) || genericTypeArgument == typeof(VcardTelephoneNumberKind)) { originalProperty = originalIenumerable.Cast().ToList(); @@ -206,6 +203,7 @@ private void ResolveUpdate(Operation operation) } var possibleDeletions = originalProperty.Except(modifiedProperty).ToList(); + if (possibleDeletions.Count > 0) { // this part will be added to the delete @@ -236,7 +234,7 @@ private void ResolveUpdate(Operation operation) { if (original[key].Equals(modifiedFull[key])) { - modified.Remove(key); + modified.Remove(key); } } } @@ -260,6 +258,7 @@ private void ResolveUpdate(Operation operation) if (listsToAdd.Count > 0) { var updateDto = modified; + foreach (var kvp in listsToAdd) { updateDto.Add(kvp.Key, kvp.Value); @@ -271,6 +270,6 @@ private void ResolveUpdate(Operation operation) { this.Update.Add(modified); } - } + } } } From b6ad0cbcfbb262d5d1624f4cf6d3c0cea2248b9d Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 15:58:16 +0100 Subject: [PATCH 02/17] Fix SQ issues --- CDP4Dal.NetCore.Tests/SessionTestFixture.cs | 17 +--- .../Cdp4DalJsonSerializer.cs | 12 +-- .../PostOperationJsonConverter.cs | 4 +- CDP4JsonSerializer/Cdp4JsonSerializer.cs | 84 ++++++++++--------- .../JsonConverter/ClasslessDtoSerializer.cs | 5 +- .../JsonConverter/ThingSerializer.cs | 11 +-- 6 files changed, 65 insertions(+), 68 deletions(-) diff --git a/CDP4Dal.NetCore.Tests/SessionTestFixture.cs b/CDP4Dal.NetCore.Tests/SessionTestFixture.cs index ee986c74a..30a16a392 100644 --- a/CDP4Dal.NetCore.Tests/SessionTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/SessionTestFixture.cs @@ -818,20 +818,11 @@ private void AssignActivePerson() [DalExport("test dal", "test dal description", "1.1.0", DalType.Web)] internal class TestDal : IDal { - public Version SupportedVersion - { - get { return new Version(1, 0, 0); } - } + public static Version SupportedVersion => new (1, 0, 0); - public Version DalVersion - { - get { return new Version("1.1.0"); } - } - - public IMetaDataProvider MetaDataProvider - { - get { return new MetaDataProvider(); } - } + public Version DalVersion => new(1, 1, 0); + + public IMetaDataProvider MetaDataProvider => new MetaDataProvider(); /// /// Gets or sets the that uses this diff --git a/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs index 5b9e6f660..cb927415d 100644 --- a/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs +++ b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs @@ -55,10 +55,9 @@ public class Cdp4DalJsonSerializer : Cdp4JsonSerializer /// The supported version of the data-model /// /// Asserts that the have to be ignored - public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedVersion, bool ignorePostOperationCopyProperty = false) + public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedVersion, bool ignorePostOperationCopyProperty = false) { this.ignorePostOperationCopyProperty = ignorePostOperationCopyProperty; - this.Initialize(metaInfoProvider, supportedVersion); } @@ -72,14 +71,11 @@ public Cdp4DalJsonSerializer(bool ignorePostOperationCopyProperty = false) } /// - /// Initialize this instance with the required and supported + /// Initialize the property /// - /// The - /// The supported - public override void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) + public override void InitializeJsonSerializerOptions() { - base.Initialize(metaInfoProvider, supportedVersion); - + base.InitializeJsonSerializerOptions(); this.JsonSerializerOptions.Converters.Add(new PostOperationJsonConverter(this.ignorePostOperationCopyProperty)); } } diff --git a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs index 90b70787c..4da5579bd 100644 --- a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs +++ b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs @@ -75,7 +75,7 @@ public override bool CanConvert(Type typeToConvert) return typeof(PostOperation).QueryIsAssignableFrom(typeToConvert); } - /// Reads and converts the JSON to type . + /// Reads and converts the JSON to type . /// The reader. /// The type to convert. /// An object that specifies serialization options to use. @@ -96,7 +96,7 @@ public override PostOperation Read(ref Utf8JsonReader reader, Type typeToConvert throw new InvalidDataException($"The request Type {typeToConvert.Name} is not a PostOperation"); } - jsonElement?.DeserializePostOperation(postOperation, options); + jsonElement.Value.DeserializePostOperation(postOperation, options); return postOperation; } diff --git a/CDP4JsonSerializer/Cdp4JsonSerializer.cs b/CDP4JsonSerializer/Cdp4JsonSerializer.cs index 2d72690bf..0294ba5a4 100644 --- a/CDP4JsonSerializer/Cdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/Cdp4JsonSerializer.cs @@ -90,15 +90,11 @@ public Cdp4JsonSerializer() /// /// The /// The supported - public virtual void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) + public void Initialize(IMetaDataProvider metaInfoProvider, Version supportedVersion) { this.MetaInfoProvider = metaInfoProvider; this.RequestDataModelVersion = supportedVersion; - - this.JsonSerializerOptions = SerializerOptions.Copy(); - this.JsonSerializerOptions.Converters.Add(new ThingSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); - this.JsonSerializerOptions.Converters.Add(new ClasslessDtoSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); - this.JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter(null, false)); + this.InitializeJsonSerializerOptions(); } /// @@ -216,6 +212,44 @@ public string SerializeToString(CDP4Common.CommonData.Thing source, bool isExten return jsonString; } + + /// + /// Serialize an object into a string + /// + /// The object to serialize + /// The serialized string + /// + /// If the or + /// has not been initialized + /// + public string SerializeToString(object toSerialize) + { + if (this.RequestDataModelVersion == null || this.MetaInfoProvider == null) + { + throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); + } + + Logger.Trace("initializing MemoryStream"); + + using var stream = new MemoryStream(); + + this.SerializeToStream(toSerialize, stream); + + Logger.Trace("rewind MemoryStream"); + stream.Position = 0; + + Logger.Trace("initializing StreamReader"); + using var reader = new StreamReader(stream); + + var sw = new Stopwatch(); + sw.Start(); + var jsonString = reader.ReadToEnd(); + sw.Stop(); + Logger.Trace("write json stream to json string in {0} [ms]", sw.ElapsedMilliseconds); + + return jsonString; + } + /// /// Convenience method that deserializes the passed in JSON content stream /// @@ -257,40 +291,14 @@ public T Deserialize(Stream contentStream) } /// - /// Serialize an object into a string + /// Initialize the property /// - /// The object to serialize - /// The serialized string - /// - /// If the or - /// has not been initialized - /// - public string SerializeToString(object toSerialize) + public virtual void InitializeJsonSerializerOptions() { - if (this.RequestDataModelVersion == null || this.MetaInfoProvider == null) - { - throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); - } - - Logger.Trace("initializing MemoryStream"); - - using var stream = new MemoryStream(); - - this.SerializeToStream(toSerialize, stream); - - Logger.Trace("rewind MemoryStream"); - stream.Position = 0; - - Logger.Trace("initializing StreamReader"); - using var reader = new StreamReader(stream); - - var sw = new Stopwatch(); - sw.Start(); - var jsonString = reader.ReadToEnd(); - sw.Stop(); - Logger.Trace("write json stream to json string in {0} [ms]", sw.ElapsedMilliseconds); - - return jsonString; + this.JsonSerializerOptions = SerializerOptions.Copy(); + this.JsonSerializerOptions.Converters.Add(new ThingSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); + this.JsonSerializerOptions.Converters.Add(new ClasslessDtoSerializer(this.MetaInfoProvider, this.RequestDataModelVersion)); + this.JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter(null, false)); } } } diff --git a/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs b/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs index 969d8bd09..a93f10eb8 100644 --- a/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs +++ b/CDP4JsonSerializer/JsonConverter/ClasslessDtoSerializer.cs @@ -25,6 +25,7 @@ namespace CDP4JsonSerializer.JsonConverter { using System; + using System.IO; using System.Text.Json; using System.Text.Json.Nodes; using System.Text.Json.Serialization; @@ -98,10 +99,10 @@ public override ClasslessDTO Read(ref Utf8JsonReader reader, Type typeToConvert, if (!JsonElement.TryParseValue(ref reader, out var jsonElement)) { Logger.Error("The data object in the JSON array could not be cast to a JsonElement type."); - throw new NullReferenceException("The data object in the JSON array could not be cast to a JsonElement type."); + throw new InvalidDataException("The data object in the JSON array could not be cast to a JsonElement type."); } - var dto = jsonElement?.ToDto(); + var dto = jsonElement.Value.ToDto(); var classlessDto = this.GenerateClasslessDto(jsonElement.Value, dto); return classlessDto; diff --git a/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs b/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs index bc8bb911b..44658341e 100644 --- a/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs +++ b/CDP4JsonSerializer/JsonConverter/ThingSerializer.cs @@ -25,6 +25,7 @@ namespace CDP4JsonSerializer.JsonConverter { using System; + using System.IO; using System.Text.Json; using System.Text.Json.Serialization; @@ -84,15 +85,15 @@ public ThingSerializer(IMetaDataProvider metaInfoProvider, Version dataModelVers /// /// Override of the can convert type check. /// - /// + /// /// The object type. /// /// /// true if this converter is to be used. /// - public override bool CanConvert(Type objectType) + public override bool CanConvert(Type typeToConvert) { - return typeof(Thing).QueryIsAssignableFrom(objectType); + return typeof(Thing).QueryIsAssignableFrom(typeToConvert); } /// @@ -108,10 +109,10 @@ public override Thing Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSe if (!JsonElement.TryParseValue(ref reader, out var jsonElement)) { Logger.Error("The data object in the JSON array could not be cast to a JsonElement type."); - throw new NullReferenceException("The data object in the JSON array could not be cast to a JsonElement type."); + throw new InvalidDataException("The data object in the JSON array could not be cast to a JsonElement type."); } - var newThing = jsonElement?.ToDto(); + var newThing = jsonElement.Value.ToDto(); return newThing; } From 3493e78d777eb3fb2a5681cded9207922d77f433 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 16:08:28 +0100 Subject: [PATCH 03/17] Update README --- README.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/README.md b/README.md index a21cdbe69..41c10e1bc 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ The CDP4-COMET Software Development Kit is an C# SDK that that is compliant with - CDP4Reporting - CDP4Dal - CDP4DalCommon + - CDP4DalJsonSerializer - CDP4JsonFileDal - CDP4ServicesDal - CDP4WspDal @@ -32,6 +33,7 @@ CDP4MessagePackSerializer | [![NuGet Badge](https://buildstats.info/nuget/CDP4Me CDP4Reporting | [![NuGet Badge](https://buildstats.info/nuget/CDP4Reporting-CE)](https://buildstats.info/nuget/CDP4Reporting-CE) CDP4Dal | [![NuGet Badge](https://buildstats.info/nuget/CDP4Dal-CE)](https://buildstats.info/nuget/CDP4Dal-CE) CDP4DalCommon | [![NuGet Badge](https://buildstats.info/nuget/CDP4DalCommon-CE)](https://buildstats.info/nuget/CDP4DalCommon-CE) +CDP4DalJsonSerializer | [![NuGet Badge](https://buildstats.info/nuget/CDP4DalJsonSerializer-CE)](https://buildstats.info/nuget/CDP4DalJsonSerializer-CE) CDP4JsonFileDal | [![NuGet Badge](https://buildstats.info/nuget/CDP4JsonFileDal-CE)](https://buildstats.info/nuget/CDP4JsonFileDal-CE) CDP4ServicesDal | [![NuGet Badge](https://buildstats.info/nuget/CDP4ServicesDal-CE)](https://buildstats.info/nuget/CDP4ServicesDal-CE) CDP4WspDal | [![NuGet Badge](https://buildstats.info/nuget/CDP4WspDal-CE)](https://buildstats.info/nuget/CDP4WspDal-CE) @@ -91,6 +93,10 @@ The CDP4Dal library is a library that provides the basis to implement ECSS-E-TM- The CDP4DalCommon library provides common classes to support the ECSS-E-TM-10-25 and CDP4-COMET protocol. +## CDP4DalJsonSerializer + +The CDP4DalJsonSerializer library provides JsonSerializer converter for common classes contained in CDP4DalCommon library. + ## CDP4JsonFileDal The CDP4JsonFileDal library is a C# library that provides an implementation of ECSS-E-TM-10-25A Annex C.3, the JSON Exchange File Format. This file format is a ZIP archive in which a number of files are stored that each contain one or more ECSS-E-TM-10-25 objects that are serialized in the form of a JSON array of JSON objects. The CDP4JsonFileDal library can be used to read from such a ZIP archive, and to create such a ZIP archive. The ZIP archive is typically used to exchange complete models between organizations. From 843b096018d9530a833ac914db947b0be879fee8 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 16:20:10 +0100 Subject: [PATCH 04/17] Fix SQ issue --- CDP4JsonSerializer/ICdp4JsonSerializer.cs | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/CDP4JsonSerializer/ICdp4JsonSerializer.cs b/CDP4JsonSerializer/ICdp4JsonSerializer.cs index 79d3bb656..5e4f1747e 100644 --- a/CDP4JsonSerializer/ICdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/ICdp4JsonSerializer.cs @@ -86,6 +86,17 @@ public interface ICdp4JsonSerializer /// A value indicating whether the contained shall be processed /// The JSON string string SerializeToString(CDP4Common.CommonData.Thing source, bool isExtentDeep); + + /// + /// Serialize an object into a string + /// + /// The object to serialize + /// The serialized string + /// + /// If the or + /// has not been initialized + /// + string SerializeToString(object toSerialize); /// /// Convenience method that deserializes the passed in JSON content stream @@ -97,16 +108,5 @@ public interface ICdp4JsonSerializer /// The the deserialized collection of . /// IEnumerable Deserialize(Stream contentStream); - - /// - /// Serialize an object into a string - /// - /// The object to serialize - /// The serialized string - /// - /// If the or - /// has not been initialized - /// - string SerializeToString(object toSerialize); } } From 721771b8f32ca12e5d74b5318e182204a4c087de Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 16:51:25 +0100 Subject: [PATCH 05/17] space indentation and encoding in all csproj file + versionbump script --- CDP4Dal/CDP4Dal.csproj | 6 +- CDP4DalCommon/CDP4DalCommon.csproj | 86 +++++++-------- .../CDP4DalJsonSerializer.csproj | 88 +++++++-------- CDP4JsonSerializer/CDP4JsonSerializer.csproj | 2 +- .../CDP4MessagePackSerializer.csproj | 92 ++++++++-------- .../CDP4RequirementsVerification.csproj | 94 ++++++++-------- CDP4Rules/CDP4Rules.csproj | 2 +- CDP4ServicesDal/CDP4ServicesDal.csproj | 4 +- .../CDP4ServicesMessaging.Tests.csproj | 14 +-- .../CDP4ServicesMessaging.csproj | 100 +++++++++--------- CDP4WspDal/CDP4WspDal.csproj | 2 +- versionBump.sh | 20 ++++ 12 files changed, 265 insertions(+), 245 deletions(-) create mode 100644 versionBump.sh diff --git a/CDP4Dal/CDP4Dal.csproj b/CDP4Dal/CDP4Dal.csproj index 806174b7d..39f6e6968 100644 --- a/CDP4Dal/CDP4Dal.csproj +++ b/CDP4Dal/CDP4Dal.csproj @@ -26,7 +26,7 @@ - + @@ -44,10 +44,10 @@ - + - \ No newline at end of file + diff --git a/CDP4DalCommon/CDP4DalCommon.csproj b/CDP4DalCommon/CDP4DalCommon.csproj index f8d4e19e4..6492b4827 100644 --- a/CDP4DalCommon/CDP4DalCommon.csproj +++ b/CDP4DalCommon/CDP4DalCommon.csproj @@ -1,43 +1,43 @@ - - - - net47;net471;net472;net48;netstandard2.0;netstandard2.1 - RHEA System S.A. - latest - CDP4DalCommon Community Edition - 26.6.0 - CDP4 Common Class Library that contains common types for any CDP4 server and the CDP4Dal - Copyright © RHEA System S.A. - Sam, Alex, Alexander, Nathanael, Antoine, Omar, Jaime - CDP4DalCommon-CE - true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition - true - cdp4-icon.png - true - true - snupkg - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git - CDP COMET ECSS-E-TM-10-25 - LGPL-3.0-only - - [BUMP] To CDP4Common 26.6.0 - - README.md - true - latest - - - - \ - true - - - \ - true - - - - - - + + + + net47;net471;net472;net48;netstandard2.0;netstandard2.1 + RHEA System S.A. + latest + CDP4DalCommon Community Edition + 26.6.0 + CDP4 Common Class Library that contains common types for any CDP4 server and the CDP4Dal + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Nathanael, Antoine, Omar, Jaime + CDP4DalCommon-CE + true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + true + latest + + + + \ + true + + + \ + true + + + + + + diff --git a/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj b/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj index 765eb528d..0d369da52 100644 --- a/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj +++ b/CDP4DalJsonSerializer/CDP4DalJsonSerializer.csproj @@ -1,44 +1,44 @@ - - - - net47;net471;net472;net48;netstandard2.0;netstandard2.1 - RHEA System S.A. - latest - CDP4DalJsonSerializer Community Edition - 26.6.0 - JsonSerializer for the CDP4DalCommon types - Copyright © RHEA System S.A. - Sam, Alex, Alexander, Nathanael, Antoine, Omar, Jaime - CDP4DalJsonSerializer-CE - true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition - true - cdp4-icon.png - true - true - snupkg - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git - CDP COMET ECSS-E-TM-10-25 - LGPL-3.0-only - - [BUMP] To CDP4Common 26.6.0 - - README.md - true - latest - - - - \ - true - - - \ - true - - - - - - - + + + + net47;net471;net472;net48;netstandard2.0;netstandard2.1 + RHEA System S.A. + latest + CDP4DalJsonSerializer Community Edition + 26.6.0 + JsonSerializer for the CDP4DalCommon types + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Nathanael, Antoine, Omar, Jaime + CDP4DalJsonSerializer-CE + true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + true + latest + + + + \ + true + + + \ + true + + + + + + + diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index 14c3d6b0f..7aa1aaf3d 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -21,7 +21,7 @@ [BUMP] To CDP4Common 26.6.0 - 11.0 + 11.0 diff --git a/CDP4MessagePackSerializer/CDP4MessagePackSerializer.csproj b/CDP4MessagePackSerializer/CDP4MessagePackSerializer.csproj index 4e7fb4f6d..141e91958 100644 --- a/CDP4MessagePackSerializer/CDP4MessagePackSerializer.csproj +++ b/CDP4MessagePackSerializer/CDP4MessagePackSerializer.csproj @@ -1,46 +1,46 @@ - - - - net47;net471;net472;net48;netstandard2.0;netstandard2.1 - RHEA System S.A. - CDP4MessagePackSerializer Community Edition - 26.6.0 - CDP4 MessagePack Serialization Library - Copyright © RHEA System S.A. - Sam, Alex, Alexander, Nathanael, Antoine, Omar - CDP4MessagePackSerializer-CE - true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition - true - cdp4-icon.png - true - true - snupkg - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git - CDP COMET ECSS-E-TM-10-25 MessagePack - LGPL-3.0-only - - [BUMP] To CDP4Common 26.6.0 - - README.md - - - - - - - - - - - - - - - - - - - - - + + + + net47;net471;net472;net48;netstandard2.0;netstandard2.1 + RHEA System S.A. + CDP4MessagePackSerializer Community Edition + 26.6.0 + CDP4 MessagePack Serialization Library + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Nathanael, Antoine, Omar + CDP4MessagePackSerializer-CE + true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 MessagePack + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + + + + + + + + + + + + + + + + + + + + + diff --git a/CDP4RequirementsVerification/CDP4RequirementsVerification.csproj b/CDP4RequirementsVerification/CDP4RequirementsVerification.csproj index 9ba6c95d7..4f30819bb 100644 --- a/CDP4RequirementsVerification/CDP4RequirementsVerification.csproj +++ b/CDP4RequirementsVerification/CDP4RequirementsVerification.csproj @@ -1,47 +1,47 @@ - - - - net47;net471;net472;net48;netstandard2.0;netstandard2.1 - RHEA System S.A. - CDP4RequirementsVerification Community Edition - 26.6.0 - CDP4 Class Library that provides requirement verification - Copyright © RHEA System S.A. - Sam, Alex, Alexander, Yevhen, Nathanael - CDP4RequirementsVerification-CE - true - http://sdk.cdp4.org - true - cdp4-icon.png - true - true - snupkg - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git - CDP COMET ECSS-E-TM-10-25 - LGPL-3.0-only - - [BUMP] To CDP4Common 26.6.0 - - README.md - - - - - - - - bin\$(Configuration)\$(TargetFramework)\$(AssemblyName).xml - $(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb - - - - - - - - - - - - - + + + + net47;net471;net472;net48;netstandard2.0;netstandard2.1 + RHEA System S.A. + CDP4RequirementsVerification Community Edition + 26.6.0 + CDP4 Class Library that provides requirement verification + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Yevhen, Nathanael + CDP4RequirementsVerification-CE + true + http://sdk.cdp4.org + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + + + + + + + + bin\$(Configuration)\$(TargetFramework)\$(AssemblyName).xml + $(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb + + + + + + + + + + + + + diff --git a/CDP4Rules/CDP4Rules.csproj b/CDP4Rules/CDP4Rules.csproj index 579d715b0..2afbe9233 100644 --- a/CDP4Rules/CDP4Rules.csproj +++ b/CDP4Rules/CDP4Rules.csproj @@ -26,7 +26,7 @@ - + diff --git a/CDP4ServicesDal/CDP4ServicesDal.csproj b/CDP4ServicesDal/CDP4ServicesDal.csproj index 7ae08223d..451b04abe 100644 --- a/CDP4ServicesDal/CDP4ServicesDal.csproj +++ b/CDP4ServicesDal/CDP4ServicesDal.csproj @@ -26,8 +26,8 @@ - - + + diff --git a/CDP4ServicesMessaging.Tests/CDP4ServicesMessaging.Tests.csproj b/CDP4ServicesMessaging.Tests/CDP4ServicesMessaging.Tests.csproj index 4d19bf081..b49795cf2 100644 --- a/CDP4ServicesMessaging.Tests/CDP4ServicesMessaging.Tests.csproj +++ b/CDP4ServicesMessaging.Tests/CDP4ServicesMessaging.Tests.csproj @@ -11,20 +11,20 @@ - + - all - runtime; build; native; contentfiles; analyzers; buildtransitive + all + runtime; build; native; contentfiles; analyzers; buildtransitive - runtime; build; native; contentfiles; analyzers; buildtransitive - all + runtime; build; native; contentfiles; analyzers; buildtransitive + all - all - runtime; build; native; contentfiles; analyzers; buildtransitive + all + runtime; build; native; contentfiles; analyzers; buildtransitive diff --git a/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj b/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj index 31b1156fd..5c08f200b 100644 --- a/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj +++ b/CDP4ServicesMessaging/CDP4ServicesMessaging.csproj @@ -1,50 +1,50 @@ - - - - netstandard2.0 - RHEA System S.A. - CDP4Common Community Edition - 26.6.0 - CDP4 Services Messaging is a Class Library that contains clients and messages class that can be used for inter services communication - Copyright © RHEA System S.A. - Sam, Alex, Alexander, Nathanael, Antoine - CDP4ServicesMessaging-CE - true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition - true - cdp4-icon.png - true - true - snupkg - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git - CDP COMET ECSS-E-TM-10-25 - LGPL-3.0-only - - [BUMP] To CDP4Common 26.6.0 - - README.md - latest - - - - - \ - true - - - \ - true - - - - - - - - - - - - - - + + + + netstandard2.0 + RHEA System S.A. + CDP4Common Community Edition + 26.6.0 + CDP4 Services Messaging is a Class Library that contains clients and messages class that can be used for inter services communication + Copyright © RHEA System S.A. + Sam, Alex, Alexander, Nathanael, Antoine + CDP4ServicesMessaging-CE + true + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition + true + cdp4-icon.png + true + true + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + CDP COMET ECSS-E-TM-10-25 + LGPL-3.0-only + + [BUMP] To CDP4Common 26.6.0 + + README.md + latest + + + + + \ + true + + + \ + true + + + + + + + + + + + + + + diff --git a/CDP4WspDal/CDP4WspDal.csproj b/CDP4WspDal/CDP4WspDal.csproj index 62ffa7c86..320a42a74 100644 --- a/CDP4WspDal/CDP4WspDal.csproj +++ b/CDP4WspDal/CDP4WspDal.csproj @@ -26,7 +26,7 @@ - + diff --git a/versionBump.sh b/versionBump.sh new file mode 100644 index 000000000..853534081 --- /dev/null +++ b/versionBump.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +if [ "$#" -ne 1 ]; then + echo "Usage: $0 " + exit 1 +fi + +rootFolder=$(pwd) + +newVersionPrefix=$1 + +# Get all .csproj files recursively within the root folder and discard tests project +projectFiles=$(find "$rootFolder" -type f -name '*.csproj' | grep -v 'Tests.csproj') + +for file in $projectFiles; do + sed "s|\(\)[^<]*\(<\/VersionPrefix>\)|\1$newVersionPrefix\2|g" "$file" > "$file.tmp" + mv "$file.tmp" "$file" +done + +echo "VersionPrefix updated to $newVersionPrefix in all .csproj files." From f1aee5c678d36f5bbe9c964a29f15cc16c689da1 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Thu, 21 Mar 2024 17:09:52 +0100 Subject: [PATCH 06/17] Missing method on ICDP4JsonSerializer interface --- CDP4JsonSerializer/ICdp4JsonSerializer.cs | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/CDP4JsonSerializer/ICdp4JsonSerializer.cs b/CDP4JsonSerializer/ICdp4JsonSerializer.cs index 5e4f1747e..452fecc12 100644 --- a/CDP4JsonSerializer/ICdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/ICdp4JsonSerializer.cs @@ -108,5 +108,19 @@ public interface ICdp4JsonSerializer /// The the deserialized collection of . /// IEnumerable Deserialize(Stream contentStream); + + /// + /// Convenience method that deserializes the passed in JSON content stream + /// + /// + /// The type info for which deserialization will be performed + /// + /// + /// The content Stream. + /// + /// + /// The the deserialized instance of the specified Type + /// + T Deserialize(Stream contentStream); } } From bb9e07a5717c510eeb564a5e894f1769dd118516 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 10:09:41 +0100 Subject: [PATCH 07/17] Added Deserialize from string --- CDP4JsonSerializer/Cdp4JsonSerializer.cs | 27 ++++++++++++++++++++++- CDP4JsonSerializer/ICdp4JsonSerializer.cs | 14 ++++++++++++ 2 files changed, 40 insertions(+), 1 deletion(-) diff --git a/CDP4JsonSerializer/Cdp4JsonSerializer.cs b/CDP4JsonSerializer/Cdp4JsonSerializer.cs index 0294ba5a4..7449cf694 100644 --- a/CDP4JsonSerializer/Cdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/Cdp4JsonSerializer.cs @@ -211,7 +211,6 @@ public string SerializeToString(CDP4Common.CommonData.Thing source, bool isExten return jsonString; } - /// /// Serialize an object into a string @@ -290,6 +289,32 @@ public T Deserialize(Stream contentStream) return data; } + /// + /// Convenience method that deserializes the passed in JSON content stream + /// + /// + /// The type info for which deserialization will be performed + /// + /// + /// The content string. + /// + /// + /// The the deserialized instance of the specified Type + /// + public T Deserialize(string contentString) + { + if (this.RequestDataModelVersion == null || this.MetaInfoProvider == null) + { + throw new InvalidOperationException("The supported version or the metainfo provider has not been set. Call the Initialize method to set them."); + } + + var sw = new Stopwatch(); + sw.Start(); + var data = JsonSerializer.Deserialize(contentString, this.JsonSerializerOptions); + Logger.Trace("Deserialize from stream in {0} [ms]", sw.ElapsedMilliseconds); + return data; + } + /// /// Initialize the property /// diff --git a/CDP4JsonSerializer/ICdp4JsonSerializer.cs b/CDP4JsonSerializer/ICdp4JsonSerializer.cs index 452fecc12..6a2aa7799 100644 --- a/CDP4JsonSerializer/ICdp4JsonSerializer.cs +++ b/CDP4JsonSerializer/ICdp4JsonSerializer.cs @@ -122,5 +122,19 @@ public interface ICdp4JsonSerializer /// The the deserialized instance of the specified Type /// T Deserialize(Stream contentStream); + + /// + /// Convenience method that deserializes the passed in JSON content stream + /// + /// + /// The type info for which deserialization will be performed + /// + /// + /// The content string. + /// + /// + /// The the deserialized instance of the specified Type + /// + T Deserialize(string contentString); } } From 585d6fb049c5e95f3a8b9f3fe353ed2cc3eb93e7 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 10:12:12 +0100 Subject: [PATCH 08/17] added snupkg --- CDP4JsonSerializer/CDP4JsonSerializer.csproj | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index 7aa1aaf3d..8477f5c22 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -1,4 +1,4 @@ - + net47;net471;net472;net48;netstandard2.0;netstandard2.1 @@ -15,7 +15,8 @@ cdp4-icon.png true true - https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git + snupkg + https://github.com/RHEAGROUP/COMET-SDK-Community-Edition.git CDP COMET ECSS-E-TM-10-25 JSON LGPL-3.0-only From 160c20804d9a653113bf2864df6ae42b98ad096d Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 11:28:26 +0100 Subject: [PATCH 09/17] PostOperation is concrete class now --- .../Operations/PostOperationTestFixture.cs | 12 --------- .../Operations/PostOperationTestFixture.cs | 12 --------- .../Protocol/Operations/PostOperation.cs | 26 +++++++++++-------- CDP4JsonSerializer/CDP4JsonSerializer.csproj | 2 +- .../CDP4ServicesDal.NetCore.Tests.csproj | 1 - .../PostOperationTestFixture.cs | 24 ----------------- CDP4ServicesDal/CdpPostOperation.cs | 22 +--------------- .../PostOperationTestFixture.cs | 24 ----------------- CDP4WspDal.Tests/PostOperationTestFixture.cs | 24 ----------------- CDP4WspDal/WSPPostOperation.cs | 22 +--------------- 10 files changed, 18 insertions(+), 151 deletions(-) diff --git a/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs b/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs index 6ded42c1c..871b511fa 100644 --- a/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs +++ b/CDP4Dal.NetCore.Tests/Operations/PostOperationTestFixture.cs @@ -50,17 +50,5 @@ public void VerifyThatConstructorSetsLists() internal class TestPostOperation : PostOperation { - public override List Delete { get; set; } - - public override List Create { get; set; } - - public override List Update { get; set; } - - public override List Copy { get; set; } - - public override void ConstructFromOperation(Operation operation) - { - throw new System.NotImplementedException(); - } } } diff --git a/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs b/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs index 6ded42c1c..871b511fa 100644 --- a/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs +++ b/CDP4Dal.Tests/Operations/PostOperationTestFixture.cs @@ -50,17 +50,5 @@ public void VerifyThatConstructorSetsLists() internal class TestPostOperation : PostOperation { - public override List Delete { get; set; } - - public override List Create { get; set; } - - public override List Update { get; set; } - - public override List Copy { get; set; } - - public override void ConstructFromOperation(Operation operation) - { - throw new System.NotImplementedException(); - } } } diff --git a/CDP4DalCommon/Protocol/Operations/PostOperation.cs b/CDP4DalCommon/Protocol/Operations/PostOperation.cs index 36c9bd4d6..7195bc1fa 100644 --- a/CDP4DalCommon/Protocol/Operations/PostOperation.cs +++ b/CDP4DalCommon/Protocol/Operations/PostOperation.cs @@ -24,6 +24,7 @@ namespace CDP4DalCommon.Protocol.Operations { + using System; using System.Collections.Generic; using CDP4Common; @@ -33,38 +34,38 @@ namespace CDP4DalCommon.Protocol.Operations /// /// The abstract super class from which all POST operations derive. /// - public abstract class PostOperation + public class PostOperation { /// /// Initializes a new instance of the class /// - protected PostOperation() + public PostOperation() { - this.Delete = new List(); - this.Create = new List(); - this.Update = new List(); - this.Copy = new List(); + this.Delete = []; + this.Create = []; + this.Update = []; + this.Copy = []; } /// /// Gets or sets the collection of DTOs to delete. /// - public abstract List Delete { get; set; } + public List Delete { get; set; } /// /// Gets or sets the collection of DTOs to create. /// - public abstract List Create { get; set; } + public List Create { get; set; } /// /// Gets or sets the collection of DTOs to update. /// - public abstract List Update { get; set; } + public List Update { get; set; } /// /// Gets or sets the collection of DTOs to copy. /// - public abstract List Copy { get; set; } + public List Copy { get; set; } /// /// Populate the current with the content based on the @@ -74,6 +75,9 @@ protected PostOperation() /// The that contains all the s that need to be /// updated to the data-source /// - public abstract void ConstructFromOperation(Operation operation); + public virtual void ConstructFromOperation(Operation operation) + { + throw new NotSupportedException("Cannot construct a PostOperation based on Operation"); + } } } diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index 8477f5c22..e2ec98c55 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -1,4 +1,4 @@ - + net47;net471;net472;net48;netstandard2.0;netstandard2.1 diff --git a/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj b/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj index 1895939a8..ad71df980 100644 --- a/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj +++ b/CDP4ServicesDal.NetCore.Tests/CDP4ServicesDal.NetCore.Tests.csproj @@ -11,7 +11,6 @@ - diff --git a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs index 02d0ce7e4..6d469df8d 100644 --- a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs @@ -140,30 +140,6 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( private class TestPostOperation : PostOperation { - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } - - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Copy { get; set; } } } } diff --git a/CDP4ServicesDal/CdpPostOperation.cs b/CDP4ServicesDal/CdpPostOperation.cs index afe1adf8c..078310b69 100644 --- a/CDP4ServicesDal/CdpPostOperation.cs +++ b/CDP4ServicesDal/CdpPostOperation.cs @@ -79,26 +79,6 @@ internal CdpPostOperation(IMetaDataProvider metaDataProvider, ISession session) this.session = session; } - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to copy. - /// - public override List Copy { get; set; } - /// /// Populate the current with the content based on the /// provided @@ -111,7 +91,7 @@ public override void ConstructFromOperation(Operation operation) { if (operation.ModifiedThing == null) { - throw new ArgumentNullException("operation", "The operation may not be null"); + throw new ArgumentNullException(nameof(operation), "The operation may not be null"); } switch (operation.OperationKind) diff --git a/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs b/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs index 1a41f72a7..581253c87 100644 --- a/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs +++ b/CDP4WspDal.NetCore.Tests/PostOperationTestFixture.cs @@ -140,30 +140,6 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( private class TestPostOperation : PostOperation { - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Copy { get; set; } - - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } } } } diff --git a/CDP4WspDal.Tests/PostOperationTestFixture.cs b/CDP4WspDal.Tests/PostOperationTestFixture.cs index 1a41f72a7..581253c87 100644 --- a/CDP4WspDal.Tests/PostOperationTestFixture.cs +++ b/CDP4WspDal.Tests/PostOperationTestFixture.cs @@ -140,30 +140,6 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( private class TestPostOperation : PostOperation { - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Copy { get; set; } - - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } } } } diff --git a/CDP4WspDal/WSPPostOperation.cs b/CDP4WspDal/WSPPostOperation.cs index 8888b2b27..df2c96eee 100644 --- a/CDP4WspDal/WSPPostOperation.cs +++ b/CDP4WspDal/WSPPostOperation.cs @@ -59,26 +59,6 @@ public WspPostOperation(IMetaDataProvider metaDataProvider) this.metaDataProvider = metaDataProvider; } - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to copy. - /// - public override List Copy { get; set; } - /// /// Populate this with the correct setup for the OCDT protocol /// @@ -89,7 +69,7 @@ public override void ConstructFromOperation(Operation operation) { if (operation.ModifiedThing == null) { - throw new ArgumentNullException("operation"); + throw new ArgumentNullException(nameof(operation)); } if (operation.OperationKind == OperationKind.Update && operation.OriginalThing == null) From 09d9365712f440b72c9943e8446b83d3ee313582 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 11:39:34 +0100 Subject: [PATCH 10/17] Improved deserialization of postoperation --- .../JsonConverter/PostOperationJsonConverter.cs | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs index 4da5579bd..7261c4eda 100644 --- a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs +++ b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs @@ -26,6 +26,7 @@ namespace CDP4DalJsonSerializer.JsonConverter { using System; using System.IO; + using System.Runtime.Serialization; using System.Text.Json; using System.Text.Json.Serialization; @@ -88,14 +89,14 @@ public override PostOperation Read(ref Utf8JsonReader reader, Type typeToConvert throw new InvalidDataException("The data object in the JSON array could not be cast to a JObject type."); } - var initializedPostOperation = Activator.CreateInstance(typeToConvert); - - if (initializedPostOperation is not PostOperation postOperation) + if (!typeof(PostOperation).IsAssignableFrom(typeToConvert)) { Logger.Error($"The request Type {typeToConvert.Name} is not a PostOperation"); throw new InvalidDataException($"The request Type {typeToConvert.Name} is not a PostOperation"); } + var postOperation = (PostOperation)FormatterServices.GetUninitializedObject(typeToConvert); + jsonElement.Value.DeserializePostOperation(postOperation, options); return postOperation; } From f155be5af762b12ff0542bb99f8b612612ff6a89 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 11:43:59 +0100 Subject: [PATCH 11/17] Remove useless constructor of PostOperation --- .../Protocol/Operations/PostOperation.cs | 19 ++++--------------- 1 file changed, 4 insertions(+), 15 deletions(-) diff --git a/CDP4DalCommon/Protocol/Operations/PostOperation.cs b/CDP4DalCommon/Protocol/Operations/PostOperation.cs index 7195bc1fa..6894d2a27 100644 --- a/CDP4DalCommon/Protocol/Operations/PostOperation.cs +++ b/CDP4DalCommon/Protocol/Operations/PostOperation.cs @@ -36,36 +36,25 @@ namespace CDP4DalCommon.Protocol.Operations /// public class PostOperation { - /// - /// Initializes a new instance of the class - /// - public PostOperation() - { - this.Delete = []; - this.Create = []; - this.Update = []; - this.Copy = []; - } - /// /// Gets or sets the collection of DTOs to delete. /// - public List Delete { get; set; } + public List Delete { get; set; } = []; /// /// Gets or sets the collection of DTOs to create. /// - public List Create { get; set; } + public List Create { get; set; } = []; /// /// Gets or sets the collection of DTOs to update. /// - public List Update { get; set; } + public List Update { get; set; } = []; /// /// Gets or sets the collection of DTOs to copy. /// - public List Copy { get; set; } + public List Copy { get; set; } = []; /// /// Populate the current with the content based on the From ebafaa49d6c0931ff18ef07be0a6e0d9764d1a56 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 13:01:12 +0100 Subject: [PATCH 12/17] Requested changes, fix build and improved PropertySerialization --- .../PostOperationJsonConverter.cs | 8 +- .../ActionItemResolver.cs | 28 +- .../ActualFiniteStateListResolver.cs | 6 +- .../ActualFiniteStateResolver.cs | 6 +- .../AutoGenDtoDeserializer/AliasResolver.cs | 10 +- .../AndExpressionResolver.cs | 4 +- .../ApprovalResolver.cs | 16 +- .../ArrayParameterTypeResolver.cs | 16 +- .../BinaryNoteResolver.cs | 16 +- .../BinaryRelationshipResolver.cs | 12 +- .../BinaryRelationshipRuleResolver.cs | 20 +- .../AutoGenDtoDeserializer/BookResolver.cs | 12 +- .../BooleanParameterTypeResolver.cs | 12 +- .../AutoGenDtoDeserializer/BoundsResolver.cs | 14 +- .../BuiltInRuleVerificationResolver.cs | 10 +- .../CategoryResolver.cs | 12 +- .../ChangeProposalResolver.cs | 24 +- .../ChangeRequestResolver.cs | 22 +- .../CitationResolver.cs | 14 +- .../AutoGenDtoDeserializer/ColorResolver.cs | 12 +- .../CommonFileStoreResolver.cs | 10 +- .../CompoundParameterTypeResolver.cs | 14 +- .../ConstantResolver.cs | 12 +- .../ContractChangeNoticeResolver.cs | 24 +- .../CyclicRatioScaleResolver.cs | 28 +- .../DateParameterTypeResolver.cs | 12 +- .../DateTimeParameterTypeResolver.cs | 12 +- .../DecompositionRuleResolver.cs | 14 +- .../DefinitionResolver.cs | 8 +- ...ependentParameterTypeAssignmentResolver.cs | 6 +- .../DerivedQuantityKindResolver.cs | 16 +- .../DerivedUnitResolver.cs | 10 +- .../DiagramCanvasResolver.cs | 8 +- .../DiagramEdgeResolver.cs | 10 +- .../DiagramObjectResolver.cs | 10 +- .../DomainFileStoreResolver.cs | 12 +- .../DomainOfExpertiseGroupResolver.cs | 10 +- .../DomainOfExpertiseResolver.cs | 10 +- .../ElementDefinitionResolver.cs | 10 +- .../ElementUsageResolver.cs | 14 +- .../EmailAddressResolver.cs | 8 +- ...ineeringModelDataDiscussionItemResolver.cs | 12 +- .../EngineeringModelDataNoteResolver.cs | 12 +- .../EngineeringModelResolver.cs | 8 +- .../EngineeringModelSetupResolver.cs | 14 +- .../EnumerationParameterTypeResolver.cs | 14 +- .../EnumerationValueDefinitionResolver.cs | 8 +- .../ExclusiveOrExpressionResolver.cs | 4 +- .../ExternalIdentifierMapResolver.cs | 14 +- .../AutoGenDtoDeserializer/FileResolver.cs | 6 +- .../FileRevisionResolver.cs | 12 +- .../FileTypeResolver.cs | 12 +- .../AutoGenDtoDeserializer/FolderResolver.cs | 12 +- .../GlossaryResolver.cs | 10 +- .../AutoGenDtoDeserializer/GoalResolver.cs | 8 +- .../HyperLinkResolver.cs | 10 +- .../IdCorrespondenceResolver.cs | 8 +- ...ependentParameterTypeAssignmentResolver.cs | 6 +- .../IntervalScaleResolver.cs | 26 +- .../IterationResolver.cs | 6 +- .../IterationSetupResolver.cs | 14 +- .../LinearConversionUnitResolver.cs | 14 +- .../LogEntryChangelogItemResolver.cs | 10 +- .../LogarithmicScaleResolver.cs | 34 +- .../MappingToReferenceScaleResolver.cs | 8 +- .../ModelLogEntryResolver.cs | 12 +- .../ModelReferenceDataLibraryResolver.cs | 8 +- .../ModellingThingReferenceResolver.cs | 8 +- .../MultiRelationshipResolver.cs | 8 +- .../MultiRelationshipRuleResolver.cs | 16 +- .../NaturalLanguageResolver.cs | 10 +- .../NestedElementResolver.cs | 8 +- .../NestedParameterResolver.cs | 14 +- .../NotExpressionResolver.cs | 6 +- .../AutoGenDtoDeserializer/OptionResolver.cs | 8 +- .../OrExpressionResolver.cs | 4 +- .../OrdinalScaleResolver.cs | 28 +- .../OrganizationResolver.cs | 10 +- .../OrganizationalParticipantResolver.cs | 6 +- .../OwnedStyleResolver.cs | 8 +- .../AutoGenDtoDeserializer/PageResolver.cs | 12 +- .../ParameterGroupResolver.cs | 6 +- .../ParameterOverrideResolver.cs | 8 +- .../ParameterOverrideValueSetResolver.cs | 8 +- .../ParameterResolver.cs | 14 +- .../ParameterSubscriptionResolver.cs | 6 +- .../ParameterSubscriptionValueSetResolver.cs | 8 +- .../ParameterTypeComponentResolver.cs | 8 +- .../ParameterValueSetResolver.cs | 6 +- .../ParameterizedCategoryRuleResolver.cs | 12 +- .../ParametricConstraintResolver.cs | 4 +- .../ParticipantPermissionResolver.cs | 10 +- .../ParticipantResolver.cs | 12 +- .../ParticipantRoleResolver.cs | 10 +- .../PersonPermissionResolver.cs | 10 +- .../AutoGenDtoDeserializer/PersonResolver.cs | 18 +- .../PersonRoleResolver.cs | 10 +- .../AutoGenDtoDeserializer/PointResolver.cs | 10 +- .../PossibleFiniteStateListResolver.cs | 10 +- .../PossibleFiniteStateResolver.cs | 8 +- .../PrefixedUnitResolver.cs | 10 +- .../PublicationResolver.cs | 6 +- .../QuantityKindFactorResolver.cs | 8 +- .../RatioScaleResolver.cs | 26 +- .../ReferenceSourceResolver.cs | 16 +- .../ReferencerRuleResolver.cs | 16 +- .../RelationalExpressionResolver.cs | 8 +- .../RelationshipParameterValueResolver.cs | 6 +- .../RequestForDeviationResolver.cs | 22 +- .../RequestForWaiverResolver.cs | 22 +- .../RequirementResolver.cs | 12 +- ...irementsContainerParameterValueResolver.cs | 6 +- .../RequirementsGroupResolver.cs | 10 +- .../RequirementsSpecificationResolver.cs | 12 +- .../ReviewItemDiscrepancyResolver.cs | 22 +- .../RuleVerificationListResolver.cs | 10 +- .../RuleViolationResolver.cs | 6 +- .../SampledFunctionParameterTypeResolver.cs | 12 +- .../ScaleReferenceQuantityValueResolver.cs | 8 +- .../ScaleValueDefinitionResolver.cs | 10 +- .../AutoGenDtoDeserializer/SectionResolver.cs | 12 +- .../SharedStyleResolver.cs | 8 +- .../SimpleParameterValueResolver.cs | 6 +- .../SimpleQuantityKindResolver.cs | 16 +- .../SimpleUnitResolver.cs | 10 +- .../SiteDirectoryDataAnnotationResolver.cs | 14 +- ...SiteDirectoryDataDiscussionItemResolver.cs | 12 +- .../SiteDirectoryResolver.cs | 12 +- .../SiteDirectoryThingReferenceResolver.cs | 8 +- .../SiteLogEntryResolver.cs | 12 +- .../SiteReferenceDataLibraryResolver.cs | 10 +- .../SolutionResolver.cs | 14 +- .../SpecializedQuantityKindResolver.cs | 18 +- .../StakeHolderValueMapResolver.cs | 8 +- .../StakeHolderValueMapSettingsResolver.cs | 4 +- .../StakeholderResolver.cs | 8 +- .../StakeholderValueResolver.cs | 8 +- .../TelephoneNumberResolver.cs | 6 +- .../AutoGenDtoDeserializer/TermResolver.cs | 10 +- .../TextParameterTypeResolver.cs | 12 +- .../TextualNoteResolver.cs | 16 +- .../TimeOfDayParameterTypeResolver.cs | 12 +- .../UnitFactorResolver.cs | 8 +- .../UnitPrefixResolver.cs | 12 +- .../UserPreferenceResolver.cs | 8 +- .../UserRuleVerificationResolver.cs | 10 +- .../ValueGroupResolver.cs | 8 +- .../ActionItemSerializer.cs | 1181 +++++------- .../ActualFiniteStateListSerializer.cs | 603 +++--- .../ActualFiniteStateSerializer.cs | 467 ++--- .../AutoGenDtoSerializer/AliasSerializer.cs | 442 ++--- .../AndExpressionSerializer.cs | 440 ++--- .../ApprovalSerializer.cs | 472 ++--- .../ArrayParameterTypeSerializer.cs | 1131 +++++------ .../BinaryNoteSerializer.cs | 533 +++-- .../BinaryRelationshipRuleSerializer.cs | 936 ++++----- .../BinaryRelationshipSerializer.cs | 599 +++--- .../AutoGenDtoSerializer/BookSerializer.cs | 550 +++--- .../BooleanParameterTypeSerializer.cs | 895 ++++----- .../AutoGenDtoSerializer/BoundsSerializer.cs | 450 ++--- .../BuiltInRuleVerificationSerializer.cs | 620 +++--- .../CategorySerializer.cs | 968 +++++----- .../ChangeProposalSerializer.cs | 1079 +++++------ .../ChangeRequestSerializer.cs | 1039 +++++----- .../CitationSerializer.cs | 496 +++-- .../AutoGenDtoSerializer/ColorSerializer.cs | 469 ++--- .../CommonFileStoreSerializer.cs | 600 +++--- .../CompoundParameterTypeSerializer.cs | 1021 +++++----- .../ConstantSerializer.cs | 977 +++++----- .../ContractChangeNoticeSerializer.cs | 1079 +++++------ .../CyclicRatioScaleSerializer.cs | 1362 ++++++------- .../DateParameterTypeSerializer.cs | 895 ++++----- .../DateTimeParameterTypeSerializer.cs | 895 ++++----- .../DecompositionRuleSerializer.cs | 983 +++++----- .../DefinitionSerializer.cs | 648 +++---- ...endentParameterTypeAssignmentSerializer.cs | 351 ++-- .../DerivedQuantityKindSerializer.cs | 1101 +++++------ .../DerivedUnitSerializer.cs | 836 ++++---- .../DiagramCanvasSerializer.cs | 506 +++-- .../DiagramEdgeSerializer.cs | 838 ++++---- .../DiagramObjectSerializer.cs | 783 ++++---- .../DomainFileStoreSerializer.cs | 627 +++--- .../DomainOfExpertiseGroupSerializer.cs | 846 ++++---- .../DomainOfExpertiseSerializer.cs | 848 ++++---- .../ElementDefinitionSerializer.cs | 1167 ++++++----- .../ElementUsageSerializer.cs | 1062 +++++----- .../EmailAddressSerializer.cs | 415 ++-- ...eeringModelDataDiscussionItemSerializer.cs | 504 +++-- .../EngineeringModelDataNoteSerializer.cs | 626 +++--- .../EngineeringModelSerializer.cs | 901 ++++----- .../EngineeringModelSetupSerializer.cs | 1280 ++++++------ .../EnumerationParameterTypeSerializer.cs | 1011 +++++----- .../EnumerationValueDefinitionSerializer.cs | 648 +++---- .../ExclusiveOrExpressionSerializer.cs | 440 ++--- .../ExternalIdentifierMapSerializer.cs | 676 +++---- .../FileRevisionSerializer.cs | 649 +++---- .../AutoGenDtoSerializer/FileSerializer.cs | 599 +++--- .../FileTypeSerializer.cs | 883 ++++----- .../AutoGenDtoSerializer/FolderSerializer.cs | 568 +++--- .../GlossarySerializer.cs | 903 ++++----- .../AutoGenDtoSerializer/GoalSerializer.cs | 628 +++--- .../HyperLinkSerializer.cs | 442 ++--- .../IdCorrespondenceSerializer.cs | 415 ++-- ...endentParameterTypeAssignmentSerializer.cs | 351 ++-- .../IntervalScaleSerializer.cs | 1227 ++++++------ .../IterationSerializer.cs | 1708 ++++++++--------- .../IterationSetupSerializer.cs | 768 ++++---- .../LinearConversionUnitSerializer.cs | 863 ++++----- .../LogEntryChangelogItemSerializer.cs | 375 ++-- .../LogarithmicScaleSerializer.cs | 1466 +++++++------- .../MappingToReferenceScaleSerializer.cs | 415 ++-- .../ModelLogEntrySerializer.cs | 896 ++++----- .../ModelReferenceDataLibrarySerializer.cs | 1367 ++++++------- .../ModellingThingReferenceSerializer.cs | 384 ++-- .../MultiRelationshipRuleSerializer.cs | 979 +++++----- .../MultiRelationshipSerializer.cs | 624 +++--- .../NaturalLanguageSerializer.cs | 442 ++--- .../NestedElementSerializer.cs | 573 +++--- .../NestedParameterSerializer.cs | 595 +++--- .../NotExpressionSerializer.cs | 388 ++-- .../AutoGenDtoSerializer/OptionSerializer.cs | 866 ++++----- .../OrExpressionSerializer.cs | 440 ++--- .../OrdinalScaleSerializer.cs | 1364 ++++++------- .../OrganizationSerializer.cs | 442 ++--- .../OrganizationalParticipantSerializer.cs | 298 ++- .../OwnedStyleSerializer.cs | 1027 +++++----- .../AutoGenDtoSerializer/PageSerializer.cs | 550 +++--- .../ParameterGroupSerializer.cs | 487 +++-- .../ParameterOverrideSerializer.cs | 573 +++--- .../ParameterOverrideValueSetSerializer.cs | 510 +++-- .../ParameterSerializer.cs | 1030 +++++----- .../ParameterSubscriptionSerializer.cs | 467 ++--- ...ParameterSubscriptionValueSetSerializer.cs | 434 ++--- .../ParameterTypeComponentSerializer.cs | 514 +++-- .../ParameterValueSetSerializer.cs | 671 +++---- .../ParameterizedCategoryRuleSerializer.cs | 869 ++++----- .../ParametricConstraintSerializer.cs | 505 +++-- .../ParticipantPermissionSerializer.cs | 442 ++--- .../ParticipantRoleSerializer.cs | 838 ++++---- .../ParticipantSerializer.cs | 548 +++--- .../PersonPermissionSerializer.cs | 442 ++--- .../PersonRoleSerializer.cs | 838 ++++---- .../AutoGenDtoSerializer/PersonSerializer.cs | 1176 +++++------- .../AutoGenDtoSerializer/PointSerializer.cs | 406 ++-- .../PossibleFiniteStateListSerializer.cs | 958 +++++---- .../PossibleFiniteStateSerializer.cs | 648 +++---- .../PrefixedUnitSerializer.cs | 741 ++++--- .../PublicationSerializer.cs | 546 +++--- .../QuantityKindFactorSerializer.cs | 415 ++-- .../RatioScaleSerializer.cs | 1227 ++++++------ .../ReferenceSourceSerializer.cs | 1161 +++++------ .../ReferencerRuleSerializer.cs | 979 +++++----- .../RelationalExpressionSerializer.cs | 533 +++-- .../RelationshipParameterValueSerializer.cs | 454 ++--- .../RequestForDeviationSerializer.cs | 1039 +++++----- .../RequestForWaiverSerializer.cs | 1039 +++++----- .../RequirementSerializer.cs | 1076 +++++------ ...ementsContainerParameterValueSerializer.cs | 454 ++--- .../RequirementsGroupSerializer.cs | 972 +++++----- .../RequirementsSpecificationSerializer.cs | 1068 +++++------ .../ReviewItemDiscrepancySerializer.cs | 1120 +++++------ .../RuleVerificationListSerializer.cs | 838 ++++---- .../RuleViolationSerializer.cs | 467 ++--- .../SampledFunctionParameterTypeSerializer.cs | 675 +++---- .../ScaleReferenceQuantityValueSerializer.cs | 415 ++-- .../ScaleValueDefinitionSerializer.cs | 741 ++++--- .../AutoGenDtoSerializer/SectionSerializer.cs | 550 +++--- .../SharedStyleSerializer.cs | 1027 +++++----- .../SimpleParameterValueSerializer.cs | 506 +++-- .../SimpleQuantityKindSerializer.cs | 1032 +++++----- .../SimpleUnitSerializer.cs | 741 ++++--- .../SiteDirectoryDataAnnotationSerializer.cs | 572 +++--- ...teDirectoryDataDiscussionItemSerializer.cs | 504 +++-- .../SiteDirectorySerializer.cs | 1410 +++++++------- .../SiteDirectoryThingReferenceSerializer.cs | 384 ++-- .../SiteLogEntrySerializer.cs | 896 ++++----- .../SiteReferenceDataLibrarySerializer.cs | 1516 +++++++-------- .../SolutionSerializer.cs | 450 ++--- .../SpecializedQuantityKindSerializer.cs | 1071 +++++------ .../StakeHolderValueMapSerializer.cs | 1041 +++++----- .../StakeHolderValueMapSettingsSerializer.cs | 538 +++--- .../StakeholderSerializer.cs | 783 ++++---- .../StakeholderValueSerializer.cs | 628 +++--- .../TelephoneNumberSerializer.cs | 467 ++--- .../AutoGenDtoSerializer/TermSerializer.cs | 741 ++++--- .../TextParameterTypeSerializer.cs | 895 ++++----- .../TextualNoteSerializer.cs | 533 +++-- .../TimeOfDayParameterTypeSerializer.cs | 895 ++++----- .../UnitFactorSerializer.cs | 415 ++-- .../UnitPrefixSerializer.cs | 808 ++++---- .../UserPreferenceSerializer.cs | 415 ++-- .../UserRuleVerificationSerializer.cs | 620 +++--- .../ValueGroupSerializer.cs | 628 +++--- CDP4JsonSerializer/CDP4JsonSerializer.csproj | 1 + .../PostOperationTestFixture.cs | 24 - 295 files changed, 50277 insertions(+), 60609 deletions(-) diff --git a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs index 7261c4eda..af260a774 100644 --- a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs +++ b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs @@ -108,7 +108,7 @@ public override PostOperation Read(ref Utf8JsonReader reader, Type typeToConvert public override void Write(Utf8JsonWriter writer, PostOperation value, JsonSerializerOptions options) { writer.WriteStartObject(); - writer.WriteStartArray("_delete"); + writer.WriteStartArray("_delete"u8); foreach (var toDelete in value.Delete) { @@ -116,7 +116,7 @@ public override void Write(Utf8JsonWriter writer, PostOperation value, JsonSeria } writer.WriteEndArray(); - writer.WriteStartArray("_create"); + writer.WriteStartArray("_create"u8); foreach (var toCreate in value.Create) { @@ -124,7 +124,7 @@ public override void Write(Utf8JsonWriter writer, PostOperation value, JsonSeria } writer.WriteEndArray(); - writer.WriteStartArray("_update"); + writer.WriteStartArray("_update"u8); foreach (var toUpdate in value.Update) { @@ -135,7 +135,7 @@ public override void Write(Utf8JsonWriter writer, PostOperation value, JsonSeria if (!this.ignoreCopyProperty) { - writer.WriteStartArray("_copy"); + writer.WriteStartArray("_copy"u8); foreach (var toCopy in value.Copy) { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs index 7e7c2b211..c4c630f61 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActionItemResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(actioneeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale actionee property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale actionee property of the actionItem {id} is null", actionItem.Iid); } else { @@ -87,7 +87,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale author property of the actionItem {id} is null", actionItem.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale classification property of the actionItem {id} is null", actionItem.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(closeOutStatementProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale closeOutStatement property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale closeOutStatement property of the actionItem {id} is null", actionItem.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale content property of the actionItem {id} is null", actionItem.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale createdOn property of the actionItem {id} is null", actionItem.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(dueDateProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale dueDate property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale dueDate property of the actionItem {id} is null", actionItem.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale languageCode property of the actionItem {id} is null", actionItem.Iid); } else { @@ -215,7 +215,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the actionItem {id} is null", actionItem.Iid); } else { @@ -227,7 +227,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale owner property of the actionItem {id} is null", actionItem.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale shortName property of the actionItem {id} is null", actionItem.Iid); } else { @@ -279,7 +279,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale status property of the actionItem {id} is null", actionItem.Iid); } else { @@ -291,7 +291,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale thingPreference property of the actionItem {id} is null", actionItem.Iid); } else { @@ -303,7 +303,7 @@ public static CDP4Common.DTO.ActionItem FromJsonObject(JsonElement jsonElement) { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the actionItem {id} is null", actionItem.Iid); + Logger.Trace("The non-nullabale title property of the actionItem {id} is null", actionItem.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs index 9ff4be99c..5f599126e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateListResolver.cs @@ -99,7 +99,7 @@ public static CDP4Common.DTO.ActualFiniteStateList FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.ActualFiniteStateList FromJsonObject(JsonElement js { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + Logger.Trace("The non-nullabale owner property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); } else { @@ -128,7 +128,7 @@ public static CDP4Common.DTO.ActualFiniteStateList FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); + Logger.Trace("The non-nullabale thingPreference property of the actualFiniteStateList {id} is null", actualFiniteStateList.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs index 152686837..97474b0d8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ActualFiniteStateResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ActualFiniteState FromJsonObject(JsonElement jsonEl { if(kindProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale kind property of the actualFiniteState {id} is null", actualFiniteState.Iid); + Logger.Trace("The non-nullabale kind property of the actualFiniteState {id} is null", actualFiniteState.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ActualFiniteState FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the actualFiniteState {id} is null", actualFiniteState.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the actualFiniteState {id} is null", actualFiniteState.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.ActualFiniteState FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the actualFiniteState {id} is null", actualFiniteState.Iid); + Logger.Trace("The non-nullabale thingPreference property of the actualFiniteState {id} is null", actualFiniteState.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs index 56a4aacfd..bb0f859c3 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/AliasResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the alias {id} is null", alias.Iid); + Logger.Trace("The non-nullabale content property of the alias {id} is null", alias.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { if(isSynonymProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isSynonym property of the alias {id} is null", alias.Iid); + Logger.Trace("The non-nullabale isSynonym property of the alias {id} is null", alias.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the alias {id} is null", alias.Iid); + Logger.Trace("The non-nullabale languageCode property of the alias {id} is null", alias.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the alias {id} is null", alias.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the alias {id} is null", alias.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Alias FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the alias {id} is null", alias.Iid); + Logger.Trace("The non-nullabale thingPreference property of the alias {id} is null", alias.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs index 1ea4589f2..51a6c7418 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/AndExpressionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.AndExpression FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the andExpression {id} is null", andExpression.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the andExpression {id} is null", andExpression.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.AndExpression FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the andExpression {id} is null", andExpression.Iid); + Logger.Trace("The non-nullabale thingPreference property of the andExpression {id} is null", andExpression.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs index a7223295e..1a8acf813 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ApprovalResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale author property of the approval {id} is null", approval.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale classification property of the approval {id} is null", approval.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale content property of the approval {id} is null", approval.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale createdOn property of the approval {id} is null", approval.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale languageCode property of the approval {id} is null", approval.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the approval {id} is null", approval.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale owner property of the approval {id} is null", approval.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.Approval FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the approval {id} is null", approval.Iid); + Logger.Trace("The non-nullabale thingPreference property of the approval {id} is null", approval.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs index c159b1b55..7468710cc 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ArrayParameterTypeResolver.cs @@ -125,7 +125,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -137,7 +137,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(isFinalizedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isFinalized property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale isFinalized property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -149,7 +149,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(isTensorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isTensor property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale isTensor property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -161,7 +161,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -173,7 +173,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale name property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -185,7 +185,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -197,7 +197,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { @@ -209,7 +209,7 @@ public static CDP4Common.DTO.ArrayParameterType FromJsonObject(JsonElement jsonE { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the arrayParameterType {id} is null", arrayParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the arrayParameterType {id} is null", arrayParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs index 0e4aa3f37..84fd7954e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryNoteResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(captionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale caption property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale caption property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -87,7 +87,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale createdOn property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(fileTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale fileType property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale fileType property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale name property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale owner property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale shortName property of the binaryNote {id} is null", binaryNote.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.BinaryNote FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the binaryNote {id} is null", binaryNote.Iid); + Logger.Trace("The non-nullabale thingPreference property of the binaryNote {id} is null", binaryNote.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs index 2f4ce317a..b324a7a2d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipResolver.cs @@ -91,7 +91,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale name property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale owner property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(sourceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale source property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale source property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(targetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale target property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale target property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.BinaryRelationship FromJsonObject(JsonElement jsonE { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the binaryRelationship {id} is null", binaryRelationship.Iid); + Logger.Trace("The non-nullabale thingPreference property of the binaryRelationship {id} is null", binaryRelationship.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs index d27b9cbf7..ee15b3b01 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BinaryRelationshipRuleResolver.cs @@ -99,7 +99,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(forwardRelationshipNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale forwardRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale forwardRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(inverseRelationshipNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale inverseRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale inverseRelationshipName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale name property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(relationshipCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale relationshipCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale relationshipCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale shortName property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(sourceCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale sourceCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale sourceCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(targetCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale targetCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale targetCategory property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { @@ -215,7 +215,7 @@ public static CDP4Common.DTO.BinaryRelationshipRule FromJsonObject(JsonElement j { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); + Logger.Trace("The non-nullabale thingPreference property of the binaryRelationshipRule {id} is null", binaryRelationshipRule.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs index 02a849837..ec7c73f59 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BookResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale createdOn property of the book {id} is null", book.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the book {id} is null", book.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale name property of the book {id} is null", book.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale owner property of the book {id} is null", book.Iid); } else { @@ -144,7 +144,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale shortName property of the book {id} is null", book.Iid); } else { @@ -156,7 +156,7 @@ public static CDP4Common.DTO.Book FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the book {id} is null", book.Iid); + Logger.Trace("The non-nullabale thingPreference property of the book {id} is null", book.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs index 78a4acd3d..3adccd1fb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BooleanParameterTypeResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale name property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.BooleanParameterType FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the booleanParameterType {id} is null", booleanParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the booleanParameterType {id} is null", booleanParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs index 040a11bd0..2ab0b5091 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BoundsResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(heightProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale height property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale height property of the bounds {id} is null", bounds.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the bounds {id} is null", bounds.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale name property of the bounds {id} is null", bounds.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale thingPreference property of the bounds {id} is null", bounds.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(widthProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale width property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale width property of the bounds {id} is null", bounds.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(xProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale x property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale x property of the bounds {id} is null", bounds.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Bounds FromJsonObject(JsonElement jsonElement) { if(yProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale y property of the bounds {id} is null", bounds.Iid); + Logger.Trace("The non-nullabale y property of the bounds {id} is null", bounds.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs index e86891285..98ff206db 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/BuiltInRuleVerificationResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement { if(isActiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isActive property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + Logger.Trace("The non-nullabale isActive property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + Logger.Trace("The non-nullabale name property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + Logger.Trace("The non-nullabale status property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.BuiltInRuleVerification FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); + Logger.Trace("The non-nullabale thingPreference property of the builtInRuleVerification {id} is null", builtInRuleVerification.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs index babc936ae..136302465 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CategoryResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(isAbstractProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isAbstract property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale isAbstract property of the category {id} is null", category.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the category {id} is null", category.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the category {id} is null", category.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale name property of the category {id} is null", category.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale shortName property of the category {id} is null", category.Iid); } else { @@ -183,7 +183,7 @@ public static CDP4Common.DTO.Category FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the category {id} is null", category.Iid); + Logger.Trace("The non-nullabale thingPreference property of the category {id} is null", category.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs index fae894ee8..d7fd3c3d1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeProposalResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale author property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(changeRequestProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale changeRequest property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale changeRequest property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale classification property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale content property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale createdOn property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale languageCode property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale owner property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale shortName property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale status property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale thingPreference property of the changeProposal {id} is null", changeProposal.Iid); } else { @@ -267,7 +267,7 @@ public static CDP4Common.DTO.ChangeProposal FromJsonObject(JsonElement jsonEleme { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the changeProposal {id} is null", changeProposal.Iid); + Logger.Trace("The non-nullabale title property of the changeProposal {id} is null", changeProposal.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs index e7cd93b16..65ee35157 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ChangeRequestResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale author property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale classification property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale content property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale createdOn property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale languageCode property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale owner property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale shortName property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -231,7 +231,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale status property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale thingPreference property of the changeRequest {id} is null", changeRequest.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.ChangeRequest FromJsonObject(JsonElement jsonElemen { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the changeRequest {id} is null", changeRequest.Iid); + Logger.Trace("The non-nullabale title property of the changeRequest {id} is null", changeRequest.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs index 7d4b2e3bd..aef860fc3 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CitationResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(isAdaptationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isAdaptation property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale isAdaptation property of the citation {id} is null", citation.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(locationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale location property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale location property of the citation {id} is null", citation.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the citation {id} is null", citation.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(remarkProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale remark property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale remark property of the citation {id} is null", citation.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale shortName property of the citation {id} is null", citation.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(sourceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale source property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale source property of the citation {id} is null", citation.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Citation FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the citation {id} is null", citation.Iid); + Logger.Trace("The non-nullabale thingPreference property of the citation {id} is null", citation.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs index 10ad217a9..ca61938e8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ColorResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(blueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale blue property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale blue property of the color {id} is null", color.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(greenProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale green property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale green property of the color {id} is null", color.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the color {id} is null", color.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale name property of the color {id} is null", color.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(redProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale red property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale red property of the color {id} is null", color.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Color FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the color {id} is null", color.Iid); + Logger.Trace("The non-nullabale thingPreference property of the color {id} is null", color.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs index 0b18fb310..0969d7170 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CommonFileStoreResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElem { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the commonFileStore {id} is null", commonFileStore.Iid); + Logger.Trace("The non-nullabale createdOn property of the commonFileStore {id} is null", commonFileStore.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the commonFileStore {id} is null", commonFileStore.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the commonFileStore {id} is null", commonFileStore.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElem { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the commonFileStore {id} is null", commonFileStore.Iid); + Logger.Trace("The non-nullabale name property of the commonFileStore {id} is null", commonFileStore.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElem { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the commonFileStore {id} is null", commonFileStore.Iid); + Logger.Trace("The non-nullabale owner property of the commonFileStore {id} is null", commonFileStore.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.CommonFileStore FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the commonFileStore {id} is null", commonFileStore.Iid); + Logger.Trace("The non-nullabale thingPreference property of the commonFileStore {id} is null", commonFileStore.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs index 565b835c6..39482bbd2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CompoundParameterTypeResolver.cs @@ -120,7 +120,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -132,7 +132,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(isFinalizedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isFinalized property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale isFinalized property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -144,7 +144,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -156,7 +156,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale name property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -168,7 +168,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -180,7 +180,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { @@ -192,7 +192,7 @@ public static CDP4Common.DTO.CompoundParameterType FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the compoundParameterType {id} is null", compoundParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the compoundParameterType {id} is null", compoundParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs index c3219160a..8b0bdcc64 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ConstantResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the constant {id} is null", constant.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the constant {id} is null", constant.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale name property of the constant {id} is null", constant.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale parameterType property of the constant {id} is null", constant.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale shortName property of the constant {id} is null", constant.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.Constant FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the constant {id} is null", constant.Iid); + Logger.Trace("The non-nullabale thingPreference property of the constant {id} is null", constant.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs index b4aa0b635..2e9024570 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ContractChangeNoticeResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale author property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(changeProposalProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale changeProposal property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale changeProposal property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale classification property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale content property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale createdOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale languageCode property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale owner property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale shortName property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale status property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale thingPreference property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { @@ -267,7 +267,7 @@ public static CDP4Common.DTO.ContractChangeNotice FromJsonObject(JsonElement jso { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); + Logger.Trace("The non-nullabale title property of the contractChangeNotice {id} is null", contractChangeNotice.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs index e479477f8..130ac64a6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/CyclicRatioScaleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMaximumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale isMaximumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMinimumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale isMinimumInclusive property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maximumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale maximumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minimumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale minimumPermissibleValue property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(modulusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modulus property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale modulus property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale name property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale negativeValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale negativeValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(numberSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale numberSet property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale numberSet property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale positiveValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale positiveValueConnotation property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale shortName property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { @@ -271,7 +271,7 @@ public static CDP4Common.DTO.CyclicRatioScale FromJsonObject(JsonElement jsonEle { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); + Logger.Trace("The non-nullabale unit property of the cyclicRatioScale {id} is null", cyclicRatioScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs index cedfd804c..0d19d7dbf 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateParameterTypeResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the dateParameterType {id} is null", dateParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the dateParameterType {id} is null", dateParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale name property of the dateParameterType {id} is null", dateParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the dateParameterType {id} is null", dateParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the dateParameterType {id} is null", dateParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.DateParameterType FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the dateParameterType {id} is null", dateParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the dateParameterType {id} is null", dateParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs index 397201bff..259457721 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DateTimeParameterTypeResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale name property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.DateTimeParameterType FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the dateTimeParameterType {id} is null", dateTimeParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs index 840efd27d..a179dc8eb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DecompositionRuleResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(containingCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale containingCategory property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale containingCategory property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(minContainedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minContained property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale minContained property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale name property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale shortName property of the decompositionRule {id} is null", decompositionRule.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.DecompositionRule FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the decompositionRule {id} is null", decompositionRule.Iid); + Logger.Trace("The non-nullabale thingPreference property of the decompositionRule {id} is null", decompositionRule.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs index 9a90885b1..3dbfce7c4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DefinitionResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.Definition FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the definition {id} is null", definition.Iid); + Logger.Trace("The non-nullabale content property of the definition {id} is null", definition.Iid); } else { @@ -108,7 +108,7 @@ public static CDP4Common.DTO.Definition FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the definition {id} is null", definition.Iid); + Logger.Trace("The non-nullabale languageCode property of the definition {id} is null", definition.Iid); } else { @@ -120,7 +120,7 @@ public static CDP4Common.DTO.Definition FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the definition {id} is null", definition.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the definition {id} is null", definition.Iid); } else { @@ -137,7 +137,7 @@ public static CDP4Common.DTO.Definition FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the definition {id} is null", definition.Iid); + Logger.Trace("The non-nullabale thingPreference property of the definition {id} is null", definition.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs index b424f62a8..6cba47589 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DependentParameterTypeAssignmentResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.DependentParameterTypeAssignment FromJsonObject(Jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.DependentParameterTypeAssignment FromJsonObject(Jso { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale parameterType property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.DependentParameterTypeAssignment FromJsonObject(Jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale thingPreference property of the dependentParameterTypeAssignment {id} is null", dependentParameterTypeAssignment.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs index 351ed6f2a..90fecb3f7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedQuantityKindResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(defaultScaleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale defaultScale property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale defaultScale property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale name property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale quantityDimensionSymbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale quantityDimensionSymbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -188,7 +188,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale shortName property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -200,7 +200,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale symbol property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { @@ -212,7 +212,7 @@ public static CDP4Common.DTO.DerivedQuantityKind FromJsonObject(JsonElement json { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); + Logger.Trace("The non-nullabale thingPreference property of the derivedQuantityKind {id} is null", derivedQuantityKind.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs index 843692006..4346800f7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DerivedUnitResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the derivedUnit {id} is null", derivedUnit.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the derivedUnit {id} is null", derivedUnit.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the derivedUnit {id} is null", derivedUnit.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the derivedUnit {id} is null", derivedUnit.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the derivedUnit {id} is null", derivedUnit.Iid); + Logger.Trace("The non-nullabale name property of the derivedUnit {id} is null", derivedUnit.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the derivedUnit {id} is null", derivedUnit.Iid); + Logger.Trace("The non-nullabale shortName property of the derivedUnit {id} is null", derivedUnit.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.DerivedUnit FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the derivedUnit {id} is null", derivedUnit.Iid); + Logger.Trace("The non-nullabale thingPreference property of the derivedUnit {id} is null", derivedUnit.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs index eb1f7514d..7ded4b613 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramCanvasResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JsonElement jsonElemen { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); + Logger.Trace("The non-nullabale createdOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the diagramCanvas {id} is null", diagramCanvas.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JsonElement jsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the diagramCanvas {id} is null", diagramCanvas.Iid); + Logger.Trace("The non-nullabale name property of the diagramCanvas {id} is null", diagramCanvas.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.DiagramCanvas FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the diagramCanvas {id} is null", diagramCanvas.Iid); + Logger.Trace("The non-nullabale thingPreference property of the diagramCanvas {id} is null", diagramCanvas.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs index c5e8aff11..dd993465d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramEdgeResolver.cs @@ -119,7 +119,7 @@ public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the diagramEdge {id} is null", diagramEdge.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the diagramEdge {id} is null", diagramEdge.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the diagramEdge {id} is null", diagramEdge.Iid); + Logger.Trace("The non-nullabale name property of the diagramEdge {id} is null", diagramEdge.Iid); } else { @@ -160,7 +160,7 @@ public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { if(sourceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale source property of the diagramEdge {id} is null", diagramEdge.Iid); + Logger.Trace("The non-nullabale source property of the diagramEdge {id} is null", diagramEdge.Iid); } else { @@ -172,7 +172,7 @@ public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { if(targetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale target property of the diagramEdge {id} is null", diagramEdge.Iid); + Logger.Trace("The non-nullabale target property of the diagramEdge {id} is null", diagramEdge.Iid); } else { @@ -184,7 +184,7 @@ public static CDP4Common.DTO.DiagramEdge FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the diagramEdge {id} is null", diagramEdge.Iid); + Logger.Trace("The non-nullabale thingPreference property of the diagramEdge {id} is null", diagramEdge.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs index be0d77768..4477d81ce 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DiagramObjectResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElemen { if(documentationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale documentation property of the diagramObject {id} is null", diagramObject.Iid); + Logger.Trace("The non-nullabale documentation property of the diagramObject {id} is null", diagramObject.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the diagramObject {id} is null", diagramObject.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the diagramObject {id} is null", diagramObject.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the diagramObject {id} is null", diagramObject.Iid); + Logger.Trace("The non-nullabale name property of the diagramObject {id} is null", diagramObject.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElemen { if(resolutionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale resolution property of the diagramObject {id} is null", diagramObject.Iid); + Logger.Trace("The non-nullabale resolution property of the diagramObject {id} is null", diagramObject.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.DiagramObject FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the diagramObject {id} is null", diagramObject.Iid); + Logger.Trace("The non-nullabale thingPreference property of the diagramObject {id} is null", diagramObject.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs index 5c95e266f..1f173b3d1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainFileStoreResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale createdOn property of the domainFileStore {id} is null", domainFileStore.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(isHiddenProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isHidden property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale isHidden property of the domainFileStore {id} is null", domainFileStore.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the domainFileStore {id} is null", domainFileStore.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale name property of the domainFileStore {id} is null", domainFileStore.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale owner property of the domainFileStore {id} is null", domainFileStore.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.DomainFileStore FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the domainFileStore {id} is null", domainFileStore.Iid); + Logger.Trace("The non-nullabale thingPreference property of the domainFileStore {id} is null", domainFileStore.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs index 842036389..59571a59a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseGroupResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement j { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement j { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement j { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + Logger.Trace("The non-nullabale name property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement j { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + Logger.Trace("The non-nullabale shortName property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.DomainOfExpertiseGroup FromJsonObject(JsonElement j { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the domainOfExpertiseGroup {id} is null", domainOfExpertiseGroup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs index 06cf55214..e81c0408d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/DomainOfExpertiseResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonEl { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + Logger.Trace("The non-nullabale name property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + Logger.Trace("The non-nullabale shortName property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.DomainOfExpertise FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); + Logger.Trace("The non-nullabale thingPreference property of the domainOfExpertise {id} is null", domainOfExpertise.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs index 91c5c81bb..5713aa4f6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementDefinitionResolver.cs @@ -123,7 +123,7 @@ public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the elementDefinition {id} is null", elementDefinition.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the elementDefinition {id} is null", elementDefinition.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the elementDefinition {id} is null", elementDefinition.Iid); + Logger.Trace("The non-nullabale name property of the elementDefinition {id} is null", elementDefinition.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonEl { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the elementDefinition {id} is null", elementDefinition.Iid); + Logger.Trace("The non-nullabale owner property of the elementDefinition {id} is null", elementDefinition.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the elementDefinition {id} is null", elementDefinition.Iid); + Logger.Trace("The non-nullabale shortName property of the elementDefinition {id} is null", elementDefinition.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.ElementDefinition FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the elementDefinition {id} is null", elementDefinition.Iid); + Logger.Trace("The non-nullabale thingPreference property of the elementDefinition {id} is null", elementDefinition.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs index 8406d81e3..56f20ecfe 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ElementUsageResolver.cs @@ -91,7 +91,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(elementDefinitionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale elementDefinition property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale elementDefinition property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(interfaceEndProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale interfaceEnd property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale interfaceEnd property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale name property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale owner property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale shortName property of the elementUsage {id} is null", elementUsage.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.ElementUsage FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the elementUsage {id} is null", elementUsage.Iid); + Logger.Trace("The non-nullabale thingPreference property of the elementUsage {id} is null", elementUsage.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs index de0fbc233..7d7d3bea3 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EmailAddressResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.EmailAddress FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the emailAddress {id} is null", emailAddress.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the emailAddress {id} is null", emailAddress.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.EmailAddress FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the emailAddress {id} is null", emailAddress.Iid); + Logger.Trace("The non-nullabale thingPreference property of the emailAddress {id} is null", emailAddress.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.EmailAddress FromJsonObject(JsonElement jsonElement { if(valueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale value property of the emailAddress {id} is null", emailAddress.Iid); + Logger.Trace("The non-nullabale value property of the emailAddress {id} is null", emailAddress.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.EmailAddress FromJsonObject(JsonElement jsonElement { if(vcardTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale vcardType property of the emailAddress {id} is null", emailAddress.Iid); + Logger.Trace("The non-nullabale vcardType property of the emailAddress {id} is null", emailAddress.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs index 3cd779c8f..4a27537a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataDiscussionItemResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale author property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale content property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale createdOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale languageCode property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.EngineeringModelDataDiscussionItem FromJsonObject(J { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale thingPreference property of the engineeringModelDataDiscussionItem {id} is null", engineeringModelDataDiscussionItem.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs index d49355db9..5c1508d82 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelDataNoteResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale author property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale content property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale createdOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale languageCode property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.EngineeringModelDataNote FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); + Logger.Trace("The non-nullabale thingPreference property of the engineeringModelDataNote {id} is null", engineeringModelDataNote.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs index f4f0ac12d..aeac88ff6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelResolver.cs @@ -80,7 +80,7 @@ public static CDP4Common.DTO.EngineeringModel FromJsonObject(JsonElement jsonEle { if(engineeringModelSetupProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale engineeringModelSetup property of the engineeringModel {id} is null", engineeringModel.Iid); + Logger.Trace("The non-nullabale engineeringModelSetup property of the engineeringModel {id} is null", engineeringModel.Iid); } else { @@ -124,7 +124,7 @@ public static CDP4Common.DTO.EngineeringModel FromJsonObject(JsonElement jsonEle { if(lastModifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale lastModifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); + Logger.Trace("The non-nullabale lastModifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); } else { @@ -152,7 +152,7 @@ public static CDP4Common.DTO.EngineeringModel FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the engineeringModel {id} is null", engineeringModel.Iid); } else { @@ -164,7 +164,7 @@ public static CDP4Common.DTO.EngineeringModel FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the engineeringModel {id} is null", engineeringModel.Iid); + Logger.Trace("The non-nullabale thingPreference property of the engineeringModel {id} is null", engineeringModel.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs index a0a05f287..1ce062d0a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EngineeringModelSetupResolver.cs @@ -103,7 +103,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(engineeringModelIidProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale engineeringModelIid property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale engineeringModelIid property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(kindProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale kind property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale kind property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale name property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -207,7 +207,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale shortName property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -231,7 +231,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(studyPhaseProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale studyPhase property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale studyPhase property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.EngineeringModelSetup FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the engineeringModelSetup {id} is null", engineeringModelSetup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs index 6059bd7aa..d3837abd6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationParameterTypeResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(allowMultiSelectProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale allowMultiSelect property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale allowMultiSelect property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale name property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.EnumerationParameterType FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the enumerationParameterType {id} is null", enumerationParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs index b0db8660e..5fa2053af 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/EnumerationValueDefinitionResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JsonEleme { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + Logger.Trace("The non-nullabale name property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JsonEleme { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + Logger.Trace("The non-nullabale shortName property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.EnumerationValueDefinition FromJsonObject(JsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); + Logger.Trace("The non-nullabale thingPreference property of the enumerationValueDefinition {id} is null", enumerationValueDefinition.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs index 62d37fbb2..1f8ab3861 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExclusiveOrExpressionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ExclusiveOrExpression FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.ExclusiveOrExpression FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); + Logger.Trace("The non-nullabale thingPreference property of the exclusiveOrExpression {id} is null", exclusiveOrExpression.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs index 242f14aac..04c37e0ff 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ExternalIdentifierMapResolver.cs @@ -103,7 +103,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(externalModelNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale externalModelName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale externalModelName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(externalToolNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale externalToolName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale externalToolName property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(externalToolVersionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale externalToolVersion property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale externalToolVersion property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale name property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale owner property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.ExternalIdentifierMap FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); + Logger.Trace("The non-nullabale thingPreference property of the externalIdentifierMap {id} is null", externalIdentifierMap.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs index d7f52a5db..c07ae429c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileResolver.cs @@ -111,7 +111,7 @@ public static CDP4Common.DTO.File FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the file {id} is null", file.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the file {id} is null", file.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.File FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the file {id} is null", file.Iid); + Logger.Trace("The non-nullabale owner property of the file {id} is null", file.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.File FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the file {id} is null", file.Iid); + Logger.Trace("The non-nullabale thingPreference property of the file {id} is null", file.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs index e7dc7b9bc..183011498 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileRevisionResolver.cs @@ -79,7 +79,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(contentHashProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale contentHash property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale contentHash property of the fileRevision {id} is null", fileRevision.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale createdOn property of the fileRevision {id} is null", fileRevision.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(creatorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale creator property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale creator property of the fileRevision {id} is null", fileRevision.Iid); } else { @@ -136,7 +136,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the fileRevision {id} is null", fileRevision.Iid); } else { @@ -148,7 +148,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale name property of the fileRevision {id} is null", fileRevision.Iid); } else { @@ -160,7 +160,7 @@ public static CDP4Common.DTO.FileRevision FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the fileRevision {id} is null", fileRevision.Iid); + Logger.Trace("The non-nullabale thingPreference property of the fileRevision {id} is null", fileRevision.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs index 15a415fa9..743c58341 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FileTypeResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(extensionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale extension property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale extension property of the fileType {id} is null", fileType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the fileType {id} is null", fileType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the fileType {id} is null", fileType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale name property of the fileType {id} is null", fileType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale shortName property of the fileType {id} is null", fileType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.FileType FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the fileType {id} is null", fileType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the fileType {id} is null", fileType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs index 61957f20b..a15b5febc 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/FolderResolver.cs @@ -79,7 +79,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale createdOn property of the folder {id} is null", folder.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(creatorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale creator property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale creator property of the folder {id} is null", folder.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the folder {id} is null", folder.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale name property of the folder {id} is null", folder.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale owner property of the folder {id} is null", folder.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Folder FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the folder {id} is null", folder.Iid); + Logger.Trace("The non-nullabale thingPreference property of the folder {id} is null", folder.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs index 0b62a5f65..0f233c960 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/GlossaryResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the glossary {id} is null", glossary.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the glossary {id} is null", glossary.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the glossary {id} is null", glossary.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the glossary {id} is null", glossary.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the glossary {id} is null", glossary.Iid); + Logger.Trace("The non-nullabale name property of the glossary {id} is null", glossary.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the glossary {id} is null", glossary.Iid); + Logger.Trace("The non-nullabale shortName property of the glossary {id} is null", glossary.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.Glossary FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the glossary {id} is null", glossary.Iid); + Logger.Trace("The non-nullabale thingPreference property of the glossary {id} is null", glossary.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs index add132c03..be107d3a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/GoalResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Goal FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the goal {id} is null", goal.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the goal {id} is null", goal.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Goal FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the goal {id} is null", goal.Iid); + Logger.Trace("The non-nullabale name property of the goal {id} is null", goal.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Goal FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the goal {id} is null", goal.Iid); + Logger.Trace("The non-nullabale shortName property of the goal {id} is null", goal.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Goal FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the goal {id} is null", goal.Iid); + Logger.Trace("The non-nullabale thingPreference property of the goal {id} is null", goal.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs index 2a47f983c..8b5405ded 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/HyperLinkResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the hyperLink {id} is null", hyperLink.Iid); + Logger.Trace("The non-nullabale content property of the hyperLink {id} is null", hyperLink.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the hyperLink {id} is null", hyperLink.Iid); + Logger.Trace("The non-nullabale languageCode property of the hyperLink {id} is null", hyperLink.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the hyperLink {id} is null", hyperLink.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the hyperLink {id} is null", hyperLink.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the hyperLink {id} is null", hyperLink.Iid); + Logger.Trace("The non-nullabale thingPreference property of the hyperLink {id} is null", hyperLink.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.HyperLink FromJsonObject(JsonElement jsonElement) { if(uriProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale uri property of the hyperLink {id} is null", hyperLink.Iid); + Logger.Trace("The non-nullabale uri property of the hyperLink {id} is null", hyperLink.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs index dc573c684..bcbf34af9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IdCorrespondenceResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JsonElement jsonEle { if(externalIdProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale externalId property of the idCorrespondence {id} is null", idCorrespondence.Iid); + Logger.Trace("The non-nullabale externalId property of the idCorrespondence {id} is null", idCorrespondence.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JsonElement jsonEle { if(internalThingProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale internalThing property of the idCorrespondence {id} is null", idCorrespondence.Iid); + Logger.Trace("The non-nullabale internalThing property of the idCorrespondence {id} is null", idCorrespondence.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the idCorrespondence {id} is null", idCorrespondence.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the idCorrespondence {id} is null", idCorrespondence.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.IdCorrespondence FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the idCorrespondence {id} is null", idCorrespondence.Iid); + Logger.Trace("The non-nullabale thingPreference property of the idCorrespondence {id} is null", idCorrespondence.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs index 2d8f77bb6..ad3bd6f91 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IndependentParameterTypeAssignmentResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.IndependentParameterTypeAssignment FromJsonObject(J { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.IndependentParameterTypeAssignment FromJsonObject(J { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale parameterType property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.IndependentParameterTypeAssignment FromJsonObject(J { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); + Logger.Trace("The non-nullabale thingPreference property of the independentParameterTypeAssignment {id} is null", independentParameterTypeAssignment.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs index ca2a5d4c8..0dd94eb40 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IntervalScaleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMaximumInclusive property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale isMaximumInclusive property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMinimumInclusive property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale isMinimumInclusive property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maximumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale maximumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minimumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale minimumPermissibleValue property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale name property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale negativeValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale negativeValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(numberSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale numberSet property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale numberSet property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale positiveValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale positiveValueConnotation property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale shortName property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the intervalScale {id} is null", intervalScale.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.IntervalScale FromJsonObject(JsonElement jsonElemen { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the intervalScale {id} is null", intervalScale.Iid); + Logger.Trace("The non-nullabale unit property of the intervalScale {id} is null", intervalScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs index ffc947b3f..c98d0a973 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationResolver.cs @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Iteration FromJsonObject(JsonElement jsonElement) { if(iterationSetupProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale iterationSetup property of the iteration {id} is null", iteration.Iid); + Logger.Trace("The non-nullabale iterationSetup property of the iteration {id} is null", iteration.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Iteration FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the iteration {id} is null", iteration.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the iteration {id} is null", iteration.Iid); } else { @@ -256,7 +256,7 @@ public static CDP4Common.DTO.Iteration FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the iteration {id} is null", iteration.Iid); + Logger.Trace("The non-nullabale thingPreference property of the iteration {id} is null", iteration.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs index c8e8447f2..74109e6a8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/IterationSetupResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale createdOn property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(descriptionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale description property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale description property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(isDeletedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeleted property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale isDeleted property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(iterationIidProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale iterationIid property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale iterationIid property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(iterationNumberProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale iterationNumber property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale iterationNumber property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the iterationSetup {id} is null", iterationSetup.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.IterationSetup FromJsonObject(JsonElement jsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the iterationSetup {id} is null", iterationSetup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the iterationSetup {id} is null", iterationSetup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs index 9cc1bca7b..5ec8444b6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LinearConversionUnitResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(conversionFactorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale conversionFactor property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale conversionFactor property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale name property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(referenceUnitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referenceUnit property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale referenceUnit property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale shortName property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.LinearConversionUnit FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); + Logger.Trace("The non-nullabale thingPreference property of the linearConversionUnit {id} is null", linearConversionUnit.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs index b36348479..797969a52 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogEntryChangelogItemResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement js { if(affectedItemIidProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale affectedItemIid property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + Logger.Trace("The non-nullabale affectedItemIid property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); } else { @@ -87,7 +87,7 @@ public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement js { if(changeDescriptionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale changeDescription property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + Logger.Trace("The non-nullabale changeDescription property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); } else { @@ -99,7 +99,7 @@ public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement js { if(changelogKindProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale changelogKind property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + Logger.Trace("The non-nullabale changelogKind property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.LogEntryChangelogItem FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); + Logger.Trace("The non-nullabale thingPreference property of the logEntryChangelogItem {id} is null", logEntryChangelogItem.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs index e7e3ecfe7..8b3a5e2d6 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/LogarithmicScaleResolver.cs @@ -99,7 +99,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(exponentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale exponent property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale exponent property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(factorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale factor property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale factor property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMaximumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale isMaximumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMinimumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale isMinimumInclusive property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(logarithmBaseProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale logarithmBase property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale logarithmBase property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maximumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale maximumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minimumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale minimumPermissibleValue property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale name property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale negativeValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale negativeValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(numberSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale numberSet property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale numberSet property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale positiveValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale positiveValueConnotation property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -271,7 +271,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(referenceQuantityKindProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referenceQuantityKind property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale referenceQuantityKind property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -291,7 +291,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale shortName property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -303,7 +303,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { @@ -315,7 +315,7 @@ public static CDP4Common.DTO.LogarithmicScale FromJsonObject(JsonElement jsonEle { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the logarithmicScale {id} is null", logarithmicScale.Iid); + Logger.Trace("The non-nullabale unit property of the logarithmicScale {id} is null", logarithmicScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs index dbb65b2f6..e9ccb89b0 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MappingToReferenceScaleResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JsonElement { if(dependentScaleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale dependentScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + Logger.Trace("The non-nullabale dependentScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JsonElement { if(referenceScaleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referenceScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + Logger.Trace("The non-nullabale referenceScaleValue property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.MappingToReferenceScale FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the mappingToReferenceScale {id} is null", mappingToReferenceScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs index 46817fdaf..b094b4c33 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelLogEntryResolver.cs @@ -103,7 +103,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale content property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale createdOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale languageCode property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(levelProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale level property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale level property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.ModelLogEntry FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the modelLogEntry {id} is null", modelLogEntry.Iid); + Logger.Trace("The non-nullabale thingPreference property of the modelLogEntry {id} is null", modelLogEntry.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs index 5490153a5..30bd10fae 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModelReferenceDataLibraryResolver.cs @@ -152,7 +152,7 @@ public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); } else { @@ -164,7 +164,7 @@ public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale name property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); } else { @@ -220,7 +220,7 @@ public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale shortName property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); } else { @@ -232,7 +232,7 @@ public static CDP4Common.DTO.ModelReferenceDataLibrary FromJsonObject(JsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale thingPreference property of the modelReferenceDataLibrary {id} is null", modelReferenceDataLibrary.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs index 9f834b6c7..0be75fb8f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ModellingThingReferenceResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the modellingThingReference {id} is null", modellingThingReference.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the modellingThingReference {id} is null", modellingThingReference.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JsonElement { if(referencedRevisionNumberProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referencedRevisionNumber property of the modellingThingReference {id} is null", modellingThingReference.Iid); + Logger.Trace("The non-nullabale referencedRevisionNumber property of the modellingThingReference {id} is null", modellingThingReference.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JsonElement { if(referencedThingProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referencedThing property of the modellingThingReference {id} is null", modellingThingReference.Iid); + Logger.Trace("The non-nullabale referencedThing property of the modellingThingReference {id} is null", modellingThingReference.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ModellingThingReference FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the modellingThingReference {id} is null", modellingThingReference.Iid); + Logger.Trace("The non-nullabale thingPreference property of the modellingThingReference {id} is null", modellingThingReference.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs index 53831176a..bb84b2ff0 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipResolver.cs @@ -91,7 +91,7 @@ public static CDP4Common.DTO.MultiRelationship FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the multiRelationship {id} is null", multiRelationship.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the multiRelationship {id} is null", multiRelationship.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.MultiRelationship FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the multiRelationship {id} is null", multiRelationship.Iid); + Logger.Trace("The non-nullabale name property of the multiRelationship {id} is null", multiRelationship.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.MultiRelationship FromJsonObject(JsonElement jsonEl { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the multiRelationship {id} is null", multiRelationship.Iid); + Logger.Trace("The non-nullabale owner property of the multiRelationship {id} is null", multiRelationship.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.MultiRelationship FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the multiRelationship {id} is null", multiRelationship.Iid); + Logger.Trace("The non-nullabale thingPreference property of the multiRelationship {id} is null", multiRelationship.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs index 8c980774c..f416dd9eb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/MultiRelationshipRuleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(maxRelatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maxRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale maxRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(minRelatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale minRelated property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale name property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(relationshipCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale relationshipCategory property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale relationshipCategory property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale shortName property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.MultiRelationshipRule FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); + Logger.Trace("The non-nullabale thingPreference property of the multiRelationshipRule {id} is null", multiRelationshipRule.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs index afc4b90e4..faf8c2fca 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NaturalLanguageResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElem { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the naturalLanguage {id} is null", naturalLanguage.Iid); + Logger.Trace("The non-nullabale languageCode property of the naturalLanguage {id} is null", naturalLanguage.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the naturalLanguage {id} is null", naturalLanguage.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the naturalLanguage {id} is null", naturalLanguage.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElem { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the naturalLanguage {id} is null", naturalLanguage.Iid); + Logger.Trace("The non-nullabale name property of the naturalLanguage {id} is null", naturalLanguage.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElem { if(nativeNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale nativeName property of the naturalLanguage {id} is null", naturalLanguage.Iid); + Logger.Trace("The non-nullabale nativeName property of the naturalLanguage {id} is null", naturalLanguage.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.NaturalLanguage FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the naturalLanguage {id} is null", naturalLanguage.Iid); + Logger.Trace("The non-nullabale thingPreference property of the naturalLanguage {id} is null", naturalLanguage.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs index d7eb62e54..267e809bc 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedElementResolver.cs @@ -88,7 +88,7 @@ public static CDP4Common.DTO.NestedElement FromJsonObject(JsonElement jsonElemen { if(isVolatileProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isVolatile property of the nestedElement {id} is null", nestedElement.Iid); + Logger.Trace("The non-nullabale isVolatile property of the nestedElement {id} is null", nestedElement.Iid); } else { @@ -100,7 +100,7 @@ public static CDP4Common.DTO.NestedElement FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the nestedElement {id} is null", nestedElement.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the nestedElement {id} is null", nestedElement.Iid); } else { @@ -120,7 +120,7 @@ public static CDP4Common.DTO.NestedElement FromJsonObject(JsonElement jsonElemen { if(rootElementProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale rootElement property of the nestedElement {id} is null", nestedElement.Iid); + Logger.Trace("The non-nullabale rootElement property of the nestedElement {id} is null", nestedElement.Iid); } else { @@ -132,7 +132,7 @@ public static CDP4Common.DTO.NestedElement FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the nestedElement {id} is null", nestedElement.Iid); + Logger.Trace("The non-nullabale thingPreference property of the nestedElement {id} is null", nestedElement.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs index 30c147689..2598bdb4f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NestedParameterResolver.cs @@ -79,7 +79,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(actualValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale actualValue property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale actualValue property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(associatedParameterProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale associatedParameter property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale associatedParameter property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(formulaProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale formula property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale formula property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(isVolatileProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isVolatile property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale isVolatile property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale owner property of the nestedParameter {id} is null", nestedParameter.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.NestedParameter FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the nestedParameter {id} is null", nestedParameter.Iid); + Logger.Trace("The non-nullabale thingPreference property of the nestedParameter {id} is null", nestedParameter.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs index 185f66df2..ced4ee8de 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/NotExpressionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.NotExpression FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the notExpression {id} is null", notExpression.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the notExpression {id} is null", notExpression.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.NotExpression FromJsonObject(JsonElement jsonElemen { if(termProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale term property of the notExpression {id} is null", notExpression.Iid); + Logger.Trace("The non-nullabale term property of the notExpression {id} is null", notExpression.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.NotExpression FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the notExpression {id} is null", notExpression.Iid); + Logger.Trace("The non-nullabale thingPreference property of the notExpression {id} is null", notExpression.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs index 72dd27d06..37f545056 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OptionResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Option FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the option {id} is null", option.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the option {id} is null", option.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Option FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the option {id} is null", option.Iid); + Logger.Trace("The non-nullabale name property of the option {id} is null", option.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.Option FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the option {id} is null", option.Iid); + Logger.Trace("The non-nullabale shortName property of the option {id} is null", option.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.Option FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the option {id} is null", option.Iid); + Logger.Trace("The non-nullabale thingPreference property of the option {id} is null", option.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs index 596b989ac..a6c5e29a7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrExpressionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.OrExpression FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the orExpression {id} is null", orExpression.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the orExpression {id} is null", orExpression.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.OrExpression FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the orExpression {id} is null", orExpression.Iid); + Logger.Trace("The non-nullabale thingPreference property of the orExpression {id} is null", orExpression.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs index fc3cb2148..28e6d26b5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrdinalScaleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMaximumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale isMaximumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMinimumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale isMinimumInclusive property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maximumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale maximumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minimumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale minimumPermissibleValue property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale name property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale negativeValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale negativeValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(numberSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale numberSet property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale numberSet property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale positiveValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale positiveValueConnotation property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale shortName property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale unit property of the ordinalScale {id} is null", ordinalScale.Iid); } else { @@ -271,7 +271,7 @@ public static CDP4Common.DTO.OrdinalScale FromJsonObject(JsonElement jsonElement { if(useShortNameValuesProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale useShortNameValues property of the ordinalScale {id} is null", ordinalScale.Iid); + Logger.Trace("The non-nullabale useShortNameValues property of the ordinalScale {id} is null", ordinalScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs index 2e50a992b..2212bddfd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the organization {id} is null", organization.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the organization {id} is null", organization.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the organization {id} is null", organization.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the organization {id} is null", organization.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the organization {id} is null", organization.Iid); + Logger.Trace("The non-nullabale name property of the organization {id} is null", organization.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the organization {id} is null", organization.Iid); + Logger.Trace("The non-nullabale shortName property of the organization {id} is null", organization.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Organization FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the organization {id} is null", organization.Iid); + Logger.Trace("The non-nullabale thingPreference property of the organization {id} is null", organization.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs index 560cbfa06..a477bc0d3 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OrganizationalParticipantResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.OrganizationalParticipant FromJsonObject(JsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.OrganizationalParticipant FromJsonObject(JsonElemen { if(organizationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale organization property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + Logger.Trace("The non-nullabale organization property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.OrganizationalParticipant FromJsonObject(JsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); + Logger.Trace("The non-nullabale thingPreference property of the organizationalParticipant {id} is null", organizationalParticipant.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs index a0c000fb4..c4c58cb19 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/OwnedStyleResolver.cs @@ -143,7 +143,7 @@ public static CDP4Common.DTO.OwnedStyle FromJsonObject(JsonElement jsonElement) { if(fontNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale fontName property of the ownedStyle {id} is null", ownedStyle.Iid); + Logger.Trace("The non-nullabale fontName property of the ownedStyle {id} is null", ownedStyle.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.OwnedStyle FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the ownedStyle {id} is null", ownedStyle.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the ownedStyle {id} is null", ownedStyle.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.OwnedStyle FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the ownedStyle {id} is null", ownedStyle.Iid); + Logger.Trace("The non-nullabale name property of the ownedStyle {id} is null", ownedStyle.Iid); } else { @@ -251,7 +251,7 @@ public static CDP4Common.DTO.OwnedStyle FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the ownedStyle {id} is null", ownedStyle.Iid); + Logger.Trace("The non-nullabale thingPreference property of the ownedStyle {id} is null", ownedStyle.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs index 80415d1e6..8e660d4c1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PageResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale createdOn property of the page {id} is null", page.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the page {id} is null", page.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale name property of the page {id} is null", page.Iid); } else { @@ -132,7 +132,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale owner property of the page {id} is null", page.Iid); } else { @@ -144,7 +144,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale shortName property of the page {id} is null", page.Iid); } else { @@ -156,7 +156,7 @@ public static CDP4Common.DTO.Page FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the page {id} is null", page.Iid); + Logger.Trace("The non-nullabale thingPreference property of the page {id} is null", page.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs index 97c0a8da7..464ab4ccd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterGroupResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ParameterGroup FromJsonObject(JsonElement jsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterGroup {id} is null", parameterGroup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterGroup {id} is null", parameterGroup.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ParameterGroup FromJsonObject(JsonElement jsonEleme { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the parameterGroup {id} is null", parameterGroup.Iid); + Logger.Trace("The non-nullabale name property of the parameterGroup {id} is null", parameterGroup.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParameterGroup FromJsonObject(JsonElement jsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterGroup {id} is null", parameterGroup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterGroup {id} is null", parameterGroup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs index 1c54ce876..581450bb9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ParameterOverride FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterOverride {id} is null", parameterOverride.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterOverride {id} is null", parameterOverride.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ParameterOverride FromJsonObject(JsonElement jsonEl { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the parameterOverride {id} is null", parameterOverride.Iid); + Logger.Trace("The non-nullabale owner property of the parameterOverride {id} is null", parameterOverride.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ParameterOverride FromJsonObject(JsonElement jsonEl { if(parameterProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameter property of the parameterOverride {id} is null", parameterOverride.Iid); + Logger.Trace("The non-nullabale parameter property of the parameterOverride {id} is null", parameterOverride.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.ParameterOverride FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterOverride {id} is null", parameterOverride.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterOverride {id} is null", parameterOverride.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs index 431d85fbb..24b52b639 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterOverrideValueSetResolver.cs @@ -96,7 +96,7 @@ public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); } else { @@ -108,7 +108,7 @@ public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JsonElemen { if(parameterValueSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterValueSet property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + Logger.Trace("The non-nullabale parameterValueSet property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); } else { @@ -128,7 +128,7 @@ public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); } else { @@ -140,7 +140,7 @@ public static CDP4Common.DTO.ParameterOverrideValueSet FromJsonObject(JsonElemen { if(valueSwitchProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale valueSwitch property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); + Logger.Trace("The non-nullabale valueSwitch property of the parameterOverrideValueSet {id} is null", parameterOverrideValueSet.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs index f122ceab5..8c6f0d9a5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(allowDifferentOwnerOfOverrideProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale allowDifferentOwnerOfOverride property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale allowDifferentOwnerOfOverride property of the parameter {id} is null", parameter.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(expectsOverrideProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale expectsOverride property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale expectsOverride property of the parameter {id} is null", parameter.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(isOptionDependentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isOptionDependent property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale isOptionDependent property of the parameter {id} is null", parameter.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameter {id} is null", parameter.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale owner property of the parameter {id} is null", parameter.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale parameterType property of the parameter {id} is null", parameter.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.Parameter FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameter {id} is null", parameter.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameter {id} is null", parameter.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs index 98f8d7966..7ed54fe41 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ParameterSubscription FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterSubscription {id} is null", parameterSubscription.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterSubscription {id} is null", parameterSubscription.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ParameterSubscription FromJsonObject(JsonElement js { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the parameterSubscription {id} is null", parameterSubscription.Iid); + Logger.Trace("The non-nullabale owner property of the parameterSubscription {id} is null", parameterSubscription.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ParameterSubscription FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterSubscription {id} is null", parameterSubscription.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterSubscription {id} is null", parameterSubscription.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs index e96359edd..07a280703 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterSubscriptionValueSetResolver.cs @@ -87,7 +87,7 @@ public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); } else { @@ -99,7 +99,7 @@ public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JsonEl { if(subscribedValueSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale subscribedValueSet property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + Logger.Trace("The non-nullabale subscribedValueSet property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); } else { @@ -111,7 +111,7 @@ public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.ParameterSubscriptionValueSet FromJsonObject(JsonEl { if(valueSwitchProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale valueSwitch property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); + Logger.Trace("The non-nullabale valueSwitch property of the parameterSubscriptionValueSet {id} is null", parameterSubscriptionValueSet.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs index 46dd2f162..8223b6a2f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterTypeComponentResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JsonElement j { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JsonElement j { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + Logger.Trace("The non-nullabale parameterType property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JsonElement j { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + Logger.Trace("The non-nullabale shortName property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ParameterTypeComponent FromJsonObject(JsonElement j { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterTypeComponent {id} is null", parameterTypeComponent.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs index c90526ee6..045a68a19 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterValueSetResolver.cs @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParameterValueSet FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterValueSet {id} is null", parameterValueSet.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterValueSet {id} is null", parameterValueSet.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.ParameterValueSet FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterValueSet {id} is null", parameterValueSet.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterValueSet {id} is null", parameterValueSet.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.ParameterValueSet FromJsonObject(JsonElement jsonEl { if(valueSwitchProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale valueSwitch property of the parameterValueSet {id} is null", parameterValueSet.Iid); + Logger.Trace("The non-nullabale valueSwitch property of the parameterValueSet {id} is null", parameterValueSet.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs index 8e2827fdf..dd07a654d 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParameterizedCategoryRuleResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(categoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale category property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale category property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale name property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale shortName property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.ParameterizedCategoryRule FromJsonObject(JsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parameterizedCategoryRule {id} is null", parameterizedCategoryRule.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs index f2d354a87..0a2167b1a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParametricConstraintResolver.cs @@ -91,7 +91,7 @@ public static CDP4Common.DTO.ParametricConstraint FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the parametricConstraint {id} is null", parametricConstraint.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the parametricConstraint {id} is null", parametricConstraint.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.ParametricConstraint FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the parametricConstraint {id} is null", parametricConstraint.Iid); + Logger.Trace("The non-nullabale thingPreference property of the parametricConstraint {id} is null", parametricConstraint.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs index fb6c00c08..c2339f659 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantPermissionResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement js { if(accessRightProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale accessRight property of the participantPermission {id} is null", participantPermission.Iid); + Logger.Trace("The non-nullabale accessRight property of the participantPermission {id} is null", participantPermission.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement js { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the participantPermission {id} is null", participantPermission.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the participantPermission {id} is null", participantPermission.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the participantPermission {id} is null", participantPermission.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the participantPermission {id} is null", participantPermission.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement js { if(objectClassProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale objectClass property of the participantPermission {id} is null", participantPermission.Iid); + Logger.Trace("The non-nullabale objectClass property of the participantPermission {id} is null", participantPermission.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ParticipantPermission FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the participantPermission {id} is null", participantPermission.Iid); + Logger.Trace("The non-nullabale thingPreference property of the participantPermission {id} is null", participantPermission.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs index 0748cf6a6..ae2e97390 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantResolver.cs @@ -91,7 +91,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(isActiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isActive property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale isActive property of the participant {id} is null", participant.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the participant {id} is null", participant.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(personProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale person property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale person property of the participant {id} is null", participant.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(roleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale role property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale role property of the participant {id} is null", participant.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(selectedDomainProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale selectedDomain property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale selectedDomain property of the participant {id} is null", participant.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Participant FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the participant {id} is null", participant.Iid); + Logger.Trace("The non-nullabale thingPreference property of the participant {id} is null", participant.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs index d9f821a41..dc98a81ec 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ParticipantRoleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElem { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the participantRole {id} is null", participantRole.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the participantRole {id} is null", participantRole.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the participantRole {id} is null", participantRole.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the participantRole {id} is null", participantRole.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElem { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the participantRole {id} is null", participantRole.Iid); + Logger.Trace("The non-nullabale name property of the participantRole {id} is null", participantRole.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElem { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the participantRole {id} is null", participantRole.Iid); + Logger.Trace("The non-nullabale shortName property of the participantRole {id} is null", participantRole.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.ParticipantRole FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the participantRole {id} is null", participantRole.Iid); + Logger.Trace("The non-nullabale thingPreference property of the participantRole {id} is null", participantRole.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs index e9bf0582a..4319167f7 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonPermissionResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonEle { if(accessRightProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale accessRight property of the personPermission {id} is null", personPermission.Iid); + Logger.Trace("The non-nullabale accessRight property of the personPermission {id} is null", personPermission.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonEle { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the personPermission {id} is null", personPermission.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the personPermission {id} is null", personPermission.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the personPermission {id} is null", personPermission.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the personPermission {id} is null", personPermission.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonEle { if(objectClassProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale objectClass property of the personPermission {id} is null", personPermission.Iid); + Logger.Trace("The non-nullabale objectClass property of the personPermission {id} is null", personPermission.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.PersonPermission FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the personPermission {id} is null", personPermission.Iid); + Logger.Trace("The non-nullabale thingPreference property of the personPermission {id} is null", personPermission.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs index e5c3c1b4b..286a55dd9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonResolver.cs @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(givenNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale givenName property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale givenName property of the person {id} is null", person.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(isActiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isActive property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale isActive property of the person {id} is null", person.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the person {id} is null", person.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the person {id} is null", person.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(organizationalUnitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale organizationalUnit property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale organizationalUnit property of the person {id} is null", person.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(passwordProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale password property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale password property of the person {id} is null", person.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale shortName property of the person {id} is null", person.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(surnameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale surname property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale surname property of the person {id} is null", person.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.Person FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the person {id} is null", person.Iid); + Logger.Trace("The non-nullabale thingPreference property of the person {id} is null", person.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs index 0b6afb333..41661b8bf 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PersonRoleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the personRole {id} is null", personRole.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the personRole {id} is null", personRole.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the personRole {id} is null", personRole.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the personRole {id} is null", personRole.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the personRole {id} is null", personRole.Iid); + Logger.Trace("The non-nullabale name property of the personRole {id} is null", personRole.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the personRole {id} is null", personRole.Iid); + Logger.Trace("The non-nullabale shortName property of the personRole {id} is null", personRole.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.PersonRole FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the personRole {id} is null", personRole.Iid); + Logger.Trace("The non-nullabale thingPreference property of the personRole {id} is null", personRole.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs index fb36ae541..cbe6fc2ac 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PointResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the point {id} is null", point.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the point {id} is null", point.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the point {id} is null", point.Iid); + Logger.Trace("The non-nullabale name property of the point {id} is null", point.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the point {id} is null", point.Iid); + Logger.Trace("The non-nullabale thingPreference property of the point {id} is null", point.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { if(xProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale x property of the point {id} is null", point.Iid); + Logger.Trace("The non-nullabale x property of the point {id} is null", point.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Point FromJsonObject(JsonElement jsonElement) { if(yProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale y property of the point {id} is null", point.Iid); + Logger.Trace("The non-nullabale y property of the point {id} is null", point.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs index 3f9da6d33..e512c0dcb 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateListResolver.cs @@ -127,7 +127,7 @@ public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + Logger.Trace("The non-nullabale name property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + Logger.Trace("The non-nullabale owner property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); } else { @@ -168,7 +168,7 @@ public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + Logger.Trace("The non-nullabale shortName property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); } else { @@ -180,7 +180,7 @@ public static CDP4Common.DTO.PossibleFiniteStateList FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); + Logger.Trace("The non-nullabale thingPreference property of the possibleFiniteStateList {id} is null", possibleFiniteStateList.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs index 03d5087d8..11535ae6f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PossibleFiniteStateResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JsonElement json { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JsonElement json { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + Logger.Trace("The non-nullabale name property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JsonElement json { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + Logger.Trace("The non-nullabale shortName property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.PossibleFiniteState FromJsonObject(JsonElement json { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); + Logger.Trace("The non-nullabale thingPreference property of the possibleFiniteState {id} is null", possibleFiniteState.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs index e5864560b..839c14026 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PrefixedUnitResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the prefixedUnit {id} is null", prefixedUnit.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the prefixedUnit {id} is null", prefixedUnit.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the prefixedUnit {id} is null", prefixedUnit.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the prefixedUnit {id} is null", prefixedUnit.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement { if(prefixProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale prefix property of the prefixedUnit {id} is null", prefixedUnit.Iid); + Logger.Trace("The non-nullabale prefix property of the prefixedUnit {id} is null", prefixedUnit.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement { if(referenceUnitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referenceUnit property of the prefixedUnit {id} is null", prefixedUnit.Iid); + Logger.Trace("The non-nullabale referenceUnit property of the prefixedUnit {id} is null", prefixedUnit.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.PrefixedUnit FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the prefixedUnit {id} is null", prefixedUnit.Iid); + Logger.Trace("The non-nullabale thingPreference property of the prefixedUnit {id} is null", prefixedUnit.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs index 8928ca912..d72f4da56 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/PublicationResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Publication FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the publication {id} is null", publication.Iid); + Logger.Trace("The non-nullabale createdOn property of the publication {id} is null", publication.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Publication FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the publication {id} is null", publication.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the publication {id} is null", publication.Iid); } else { @@ -123,7 +123,7 @@ public static CDP4Common.DTO.Publication FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the publication {id} is null", publication.Iid); + Logger.Trace("The non-nullabale thingPreference property of the publication {id} is null", publication.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs index ce4a93914..089263793 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/QuantityKindFactorResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JsonElement jsonE { if(exponentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale exponent property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + Logger.Trace("The non-nullabale exponent property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JsonElement jsonE { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JsonElement jsonE { if(quantityKindProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale quantityKind property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + Logger.Trace("The non-nullabale quantityKind property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.QuantityKindFactor FromJsonObject(JsonElement jsonE { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); + Logger.Trace("The non-nullabale thingPreference property of the quantityKindFactor {id} is null", quantityKindFactor.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs index 3f4d494dc..7cf7008c1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RatioScaleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(isMaximumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMaximumInclusive property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale isMaximumInclusive property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(isMinimumInclusiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isMinimumInclusive property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale isMinimumInclusive property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(maximumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maximumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale maximumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(minimumPermissibleValueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minimumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale minimumPermissibleValue property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale name property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(negativeValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale negativeValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale negativeValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(numberSetProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale numberSet property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale numberSet property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(positiveValueConnotationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale positiveValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale positiveValueConnotation property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale shortName property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale thingPreference property of the ratioScale {id} is null", ratioScale.Iid); } else { @@ -259,7 +259,7 @@ public static CDP4Common.DTO.RatioScale FromJsonObject(JsonElement jsonElement) { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the ratioScale {id} is null", ratioScale.Iid); + Logger.Trace("The non-nullabale unit property of the ratioScale {id} is null", ratioScale.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs index 4590d1a68..b32c08056 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferenceSourceResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale author property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(languageProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale language property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale language property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale name property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale shortName property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -223,7 +223,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale thingPreference property of the referenceSource {id} is null", referenceSource.Iid); } else { @@ -247,7 +247,7 @@ public static CDP4Common.DTO.ReferenceSource FromJsonObject(JsonElement jsonElem { if(versionIdentifierProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale versionIdentifier property of the referenceSource {id} is null", referenceSource.Iid); + Logger.Trace("The non-nullabale versionIdentifier property of the referenceSource {id} is null", referenceSource.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs index c965a9f79..fc0f56672 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReferencerRuleResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(maxReferencedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale maxReferenced property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale maxReferenced property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(minReferencedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale minReferenced property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale minReferenced property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale name property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(referencingCategoryProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referencingCategory property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale referencingCategory property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale shortName property of the referencerRule {id} is null", referencerRule.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.ReferencerRule FromJsonObject(JsonElement jsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the referencerRule {id} is null", referencerRule.Iid); + Logger.Trace("The non-nullabale thingPreference property of the referencerRule {id} is null", referencerRule.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs index 77c392685..ca549cad2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationalExpressionResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.RelationalExpression FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the relationalExpression {id} is null", relationalExpression.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the relationalExpression {id} is null", relationalExpression.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RelationalExpression FromJsonObject(JsonElement jso { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the relationalExpression {id} is null", relationalExpression.Iid); + Logger.Trace("The non-nullabale parameterType property of the relationalExpression {id} is null", relationalExpression.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RelationalExpression FromJsonObject(JsonElement jso { if(relationalOperatorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale relationalOperator property of the relationalExpression {id} is null", relationalExpression.Iid); + Logger.Trace("The non-nullabale relationalOperator property of the relationalExpression {id} is null", relationalExpression.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.RelationalExpression FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the relationalExpression {id} is null", relationalExpression.Iid); + Logger.Trace("The non-nullabale thingPreference property of the relationalExpression {id} is null", relationalExpression.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs index 8437ea8ad..65c5f9236 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RelationshipParameterValueResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.RelationshipParameterValue FromJsonObject(JsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RelationshipParameterValue FromJsonObject(JsonEleme { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + Logger.Trace("The non-nullabale parameterType property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RelationshipParameterValue FromJsonObject(JsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); + Logger.Trace("The non-nullabale thingPreference property of the relationshipParameterValue {id} is null", relationshipParameterValue.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs index f4bd88419..e3f87ec31 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForDeviationResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale author property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale classification property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale content property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale createdOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale languageCode property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale owner property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale shortName property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -231,7 +231,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale status property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.RequestForDeviation FromJsonObject(JsonElement json { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the requestForDeviation {id} is null", requestForDeviation.Iid); + Logger.Trace("The non-nullabale title property of the requestForDeviation {id} is null", requestForDeviation.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs index e957a5040..a56451c6b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequestForWaiverResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale author property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale classification property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale content property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale createdOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale languageCode property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale owner property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale shortName property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -231,7 +231,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale status property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -243,7 +243,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.RequestForWaiver FromJsonObject(JsonElement jsonEle { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the requestForWaiver {id} is null", requestForWaiver.Iid); + Logger.Trace("The non-nullabale title property of the requestForWaiver {id} is null", requestForWaiver.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs index 5fde343c5..2d7adbcde 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementResolver.cs @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the requirement {id} is null", requirement.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requirement {id} is null", requirement.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale name property of the requirement {id} is null", requirement.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale owner property of the requirement {id} is null", requirement.Iid); } else { @@ -188,7 +188,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale shortName property of the requirement {id} is null", requirement.Iid); } else { @@ -200,7 +200,7 @@ public static CDP4Common.DTO.Requirement FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requirement {id} is null", requirement.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requirement {id} is null", requirement.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs index 634d5fbf4..4fbdf07aa 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsContainerParameterValueResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.RequirementsContainerParameterValue FromJsonObject( { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RequirementsContainerParameterValue FromJsonObject( { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + Logger.Trace("The non-nullabale parameterType property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RequirementsContainerParameterValue FromJsonObject( { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requirementsContainerParameterValue {id} is null", requirementsContainerParameterValue.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs index b6e4218e1..1439abe7f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsGroupResolver.cs @@ -123,7 +123,7 @@ public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requirementsGroup {id} is null", requirementsGroup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requirementsGroup {id} is null", requirementsGroup.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the requirementsGroup {id} is null", requirementsGroup.Iid); + Logger.Trace("The non-nullabale name property of the requirementsGroup {id} is null", requirementsGroup.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonEl { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the requirementsGroup {id} is null", requirementsGroup.Iid); + Logger.Trace("The non-nullabale owner property of the requirementsGroup {id} is null", requirementsGroup.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the requirementsGroup {id} is null", requirementsGroup.Iid); + Logger.Trace("The non-nullabale shortName property of the requirementsGroup {id} is null", requirementsGroup.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.RequirementsGroup FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requirementsGroup {id} is null", requirementsGroup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requirementsGroup {id} is null", requirementsGroup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs index 423026111..c6cb5b0c4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RequirementsSpecificationResolver.cs @@ -123,7 +123,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { @@ -147,7 +147,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale name property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale owner property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale shortName property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { @@ -199,7 +199,7 @@ public static CDP4Common.DTO.RequirementsSpecification FromJsonObject(JsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); + Logger.Trace("The non-nullabale thingPreference property of the requirementsSpecification {id} is null", requirementsSpecification.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs index ad2873076..163e50852 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ReviewItemDiscrepancyResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale author property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(classificationProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale classification property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale classification property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale content property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale createdOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale languageCode property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -179,7 +179,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale owner property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -211,7 +211,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale shortName property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -239,7 +239,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale status property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -251,7 +251,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale thingPreference property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { @@ -263,7 +263,7 @@ public static CDP4Common.DTO.ReviewItemDiscrepancy FromJsonObject(JsonElement js { if(titleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale title property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); + Logger.Trace("The non-nullabale title property of the reviewItemDiscrepancy {id} is null", reviewItemDiscrepancy.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs index 428b4121e..2d970f525 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleVerificationListResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jso { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + Logger.Trace("The non-nullabale name property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jso { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + Logger.Trace("The non-nullabale owner property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); } else { @@ -148,7 +148,7 @@ public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jso { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + Logger.Trace("The non-nullabale shortName property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); } else { @@ -160,7 +160,7 @@ public static CDP4Common.DTO.RuleVerificationList FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); + Logger.Trace("The non-nullabale thingPreference property of the ruleVerificationList {id} is null", ruleVerificationList.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs index 45199c0de..45a79e1df 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/RuleViolationResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.RuleViolation FromJsonObject(JsonElement jsonElemen { if(descriptionProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale description property of the ruleViolation {id} is null", ruleViolation.Iid); + Logger.Trace("The non-nullabale description property of the ruleViolation {id} is null", ruleViolation.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.RuleViolation FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the ruleViolation {id} is null", ruleViolation.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the ruleViolation {id} is null", ruleViolation.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.RuleViolation FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the ruleViolation {id} is null", ruleViolation.Iid); + Logger.Trace("The non-nullabale thingPreference property of the ruleViolation {id} is null", ruleViolation.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs index c1d7c617e..946660f7c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SampledFunctionParameterTypeResolver.cs @@ -141,7 +141,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { @@ -153,7 +153,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { @@ -165,7 +165,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale name property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { @@ -177,7 +177,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { @@ -189,7 +189,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { @@ -201,7 +201,7 @@ public static CDP4Common.DTO.SampledFunctionParameterType FromJsonObject(JsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the sampledFunctionParameterType {id} is null", sampledFunctionParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs index fde46eb30..4b915e1f5 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleReferenceQuantityValueResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JsonElem { if(scaleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale scale property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + Logger.Trace("The non-nullabale scale property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + Logger.Trace("The non-nullabale thingPreference property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ScaleReferenceQuantityValue FromJsonObject(JsonElem { if(valueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale value property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); + Logger.Trace("The non-nullabale value property of the scaleReferenceQuantityValue {id} is null", scaleReferenceQuantityValue.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs index 3979cde6d..819ab270f 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ScaleValueDefinitionResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jso { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + Logger.Trace("The non-nullabale name property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jso { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + Logger.Trace("The non-nullabale shortName property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + Logger.Trace("The non-nullabale thingPreference property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.ScaleValueDefinition FromJsonObject(JsonElement jso { if(valueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale value property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); + Logger.Trace("The non-nullabale value property of the scaleValueDefinition {id} is null", scaleValueDefinition.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs index 9dbef1bc9..9fc4e315c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SectionResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale createdOn property of the section {id} is null", section.Iid); } else { @@ -103,7 +103,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the section {id} is null", section.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale name property of the section {id} is null", section.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale owner property of the section {id} is null", section.Iid); } else { @@ -144,7 +144,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale shortName property of the section {id} is null", section.Iid); } else { @@ -156,7 +156,7 @@ public static CDP4Common.DTO.Section FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the section {id} is null", section.Iid); + Logger.Trace("The non-nullabale thingPreference property of the section {id} is null", section.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs index 3508f96dd..cfa19318a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SharedStyleResolver.cs @@ -143,7 +143,7 @@ public static CDP4Common.DTO.SharedStyle FromJsonObject(JsonElement jsonElement) { if(fontNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale fontName property of the sharedStyle {id} is null", sharedStyle.Iid); + Logger.Trace("The non-nullabale fontName property of the sharedStyle {id} is null", sharedStyle.Iid); } else { @@ -191,7 +191,7 @@ public static CDP4Common.DTO.SharedStyle FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the sharedStyle {id} is null", sharedStyle.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the sharedStyle {id} is null", sharedStyle.Iid); } else { @@ -203,7 +203,7 @@ public static CDP4Common.DTO.SharedStyle FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the sharedStyle {id} is null", sharedStyle.Iid); + Logger.Trace("The non-nullabale name property of the sharedStyle {id} is null", sharedStyle.Iid); } else { @@ -251,7 +251,7 @@ public static CDP4Common.DTO.SharedStyle FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the sharedStyle {id} is null", sharedStyle.Iid); + Logger.Trace("The non-nullabale thingPreference property of the sharedStyle {id} is null", sharedStyle.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs index bcc744308..fa8f3b82c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleParameterValueResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.SimpleParameterValue FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.SimpleParameterValue FromJsonObject(JsonElement jso { if(parameterTypeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale parameterType property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + Logger.Trace("The non-nullabale parameterType property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.SimpleParameterValue FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); + Logger.Trace("The non-nullabale thingPreference property of the simpleParameterValue {id} is null", simpleParameterValue.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs index b7b864b58..d3cf8a6e2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleQuantityKindResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(defaultScaleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale defaultScale property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale defaultScale property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale name property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale quantityDimensionSymbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale quantityDimensionSymbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -183,7 +183,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale shortName property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -195,7 +195,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale symbol property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { @@ -207,7 +207,7 @@ public static CDP4Common.DTO.SimpleQuantityKind FromJsonObject(JsonElement jsonE { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); + Logger.Trace("The non-nullabale thingPreference property of the simpleQuantityKind {id} is null", simpleQuantityKind.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs index 53ac8fc41..2e4812866 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SimpleUnitResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the simpleUnit {id} is null", simpleUnit.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the simpleUnit {id} is null", simpleUnit.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the simpleUnit {id} is null", simpleUnit.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the simpleUnit {id} is null", simpleUnit.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the simpleUnit {id} is null", simpleUnit.Iid); + Logger.Trace("The non-nullabale name property of the simpleUnit {id} is null", simpleUnit.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the simpleUnit {id} is null", simpleUnit.Iid); + Logger.Trace("The non-nullabale shortName property of the simpleUnit {id} is null", simpleUnit.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.SimpleUnit FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the simpleUnit {id} is null", simpleUnit.Iid); + Logger.Trace("The non-nullabale thingPreference property of the simpleUnit {id} is null", simpleUnit.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs index 2d60b0f17..68d422c8b 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataAnnotationResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale author property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale content property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale createdOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale languageCode property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(primaryAnnotatedThingProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale primaryAnnotatedThing property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale primaryAnnotatedThing property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.SiteDirectoryDataAnnotation FromJsonObject(JsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteDirectoryDataAnnotation {id} is null", siteDirectoryDataAnnotation.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs index 71d006535..459029ada 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryDataDiscussionItemResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale author property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale content property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale createdOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale languageCode property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.SiteDirectoryDataDiscussionItem FromJsonObject(Json { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteDirectoryDataDiscussionItem {id} is null", siteDirectoryDataDiscussionItem.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs index 57db9f6e4..6c3350b55 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale createdOn property of the siteDirectory {id} is null", siteDirectory.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(lastModifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale lastModifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale lastModifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); } else { @@ -171,7 +171,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteDirectory {id} is null", siteDirectory.Iid); } else { @@ -183,7 +183,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale name property of the siteDirectory {id} is null", siteDirectory.Iid); } else { @@ -235,7 +235,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale shortName property of the siteDirectory {id} is null", siteDirectory.Iid); } else { @@ -255,7 +255,7 @@ public static CDP4Common.DTO.SiteDirectory FromJsonObject(JsonElement jsonElemen { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteDirectory {id} is null", siteDirectory.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteDirectory {id} is null", siteDirectory.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs index 28946bf18..11ccc900c 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteDirectoryThingReferenceResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JsonElem { if(referencedRevisionNumberProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referencedRevisionNumber property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + Logger.Trace("The non-nullabale referencedRevisionNumber property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JsonElem { if(referencedThingProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale referencedThing property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + Logger.Trace("The non-nullabale referencedThing property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.SiteDirectoryThingReference FromJsonObject(JsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteDirectoryThingReference {id} is null", siteDirectoryThingReference.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs index 2e9c5fabe..a3c5db285 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteLogEntryResolver.cs @@ -103,7 +103,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale content property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale createdOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale languageCode property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(levelProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale level property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale level property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { @@ -187,7 +187,7 @@ public static CDP4Common.DTO.SiteLogEntry FromJsonObject(JsonElement jsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteLogEntry {id} is null", siteLogEntry.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteLogEntry {id} is null", siteLogEntry.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs index fc7c9afdf..dd212ecb4 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SiteReferenceDataLibraryResolver.cs @@ -152,7 +152,7 @@ public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); } else { @@ -164,7 +164,7 @@ public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); } else { @@ -176,7 +176,7 @@ public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale name property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); } else { @@ -232,7 +232,7 @@ public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale shortName property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); } else { @@ -244,7 +244,7 @@ public static CDP4Common.DTO.SiteReferenceDataLibrary FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); + Logger.Trace("The non-nullabale thingPreference property of the siteReferenceDataLibrary {id} is null", siteReferenceDataLibrary.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs index 37940cf95..9d427ee8a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SolutionResolver.cs @@ -67,7 +67,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(authorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale author property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale author property of the solution {id} is null", solution.Iid); } else { @@ -79,7 +79,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale content property of the solution {id} is null", solution.Iid); } else { @@ -91,7 +91,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale createdOn property of the solution {id} is null", solution.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale languageCode property of the solution {id} is null", solution.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the solution {id} is null", solution.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale owner property of the solution {id} is null", solution.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Solution FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the solution {id} is null", solution.Iid); + Logger.Trace("The non-nullabale thingPreference property of the solution {id} is null", solution.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs index dc593f909..8c7076c26 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/SpecializedQuantityKindResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(defaultScaleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale defaultScale property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale defaultScale property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(generalProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale general property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale general property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale name property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -183,7 +183,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(quantityDimensionSymbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale quantityDimensionSymbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale quantityDimensionSymbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -195,7 +195,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale shortName property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -207,7 +207,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale symbol property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { @@ -219,7 +219,7 @@ public static CDP4Common.DTO.SpecializedQuantityKind FromJsonObject(JsonElement { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); + Logger.Trace("The non-nullabale thingPreference property of the specializedQuantityKind {id} is null", specializedQuantityKind.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs index 2a3d0bc4f..5795d07a2 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapResolver.cs @@ -123,7 +123,7 @@ public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JsonElement json { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); } else { @@ -135,7 +135,7 @@ public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JsonElement json { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + Logger.Trace("The non-nullabale name property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JsonElement json { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + Logger.Trace("The non-nullabale shortName property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); } else { @@ -183,7 +183,7 @@ public static CDP4Common.DTO.StakeHolderValueMap FromJsonObject(JsonElement json { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); + Logger.Trace("The non-nullabale thingPreference property of the stakeHolderValueMap {id} is null", stakeHolderValueMap.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs index cf611c630..9863c5486 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeHolderValueMapSettingsResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.StakeHolderValueMapSettings FromJsonObject(JsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.StakeHolderValueMapSettings FromJsonObject(JsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); + Logger.Trace("The non-nullabale thingPreference property of the stakeHolderValueMapSettings {id} is null", stakeHolderValueMapSettings.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs index 36e471fef..2a4191a5a 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.Stakeholder FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the stakeholder {id} is null", stakeholder.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the stakeholder {id} is null", stakeholder.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.Stakeholder FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the stakeholder {id} is null", stakeholder.Iid); + Logger.Trace("The non-nullabale name property of the stakeholder {id} is null", stakeholder.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.Stakeholder FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the stakeholder {id} is null", stakeholder.Iid); + Logger.Trace("The non-nullabale shortName property of the stakeholder {id} is null", stakeholder.Iid); } else { @@ -159,7 +159,7 @@ public static CDP4Common.DTO.Stakeholder FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the stakeholder {id} is null", stakeholder.Iid); + Logger.Trace("The non-nullabale thingPreference property of the stakeholder {id} is null", stakeholder.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs index be7fa1876..88d7c6a47 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/StakeholderValueResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.StakeholderValue FromJsonObject(JsonElement jsonEle { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the stakeholderValue {id} is null", stakeholderValue.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the stakeholderValue {id} is null", stakeholderValue.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.StakeholderValue FromJsonObject(JsonElement jsonEle { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the stakeholderValue {id} is null", stakeholderValue.Iid); + Logger.Trace("The non-nullabale name property of the stakeholderValue {id} is null", stakeholderValue.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.StakeholderValue FromJsonObject(JsonElement jsonEle { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the stakeholderValue {id} is null", stakeholderValue.Iid); + Logger.Trace("The non-nullabale shortName property of the stakeholderValue {id} is null", stakeholderValue.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.StakeholderValue FromJsonObject(JsonElement jsonEle { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the stakeholderValue {id} is null", stakeholderValue.Iid); + Logger.Trace("The non-nullabale thingPreference property of the stakeholderValue {id} is null", stakeholderValue.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs index 775ad6bde..95b744ffe 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TelephoneNumberResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.TelephoneNumber FromJsonObject(JsonElement jsonElem { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the telephoneNumber {id} is null", telephoneNumber.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the telephoneNumber {id} is null", telephoneNumber.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.TelephoneNumber FromJsonObject(JsonElement jsonElem { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the telephoneNumber {id} is null", telephoneNumber.Iid); + Logger.Trace("The non-nullabale thingPreference property of the telephoneNumber {id} is null", telephoneNumber.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.TelephoneNumber FromJsonObject(JsonElement jsonElem { if(valueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale value property of the telephoneNumber {id} is null", telephoneNumber.Iid); + Logger.Trace("The non-nullabale value property of the telephoneNumber {id} is null", telephoneNumber.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs index a2a92daa0..ed17540c9 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TermResolver.cs @@ -107,7 +107,7 @@ public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the term {id} is null", term.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the term {id} is null", term.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the term {id} is null", term.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the term {id} is null", term.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the term {id} is null", term.Iid); + Logger.Trace("The non-nullabale name property of the term {id} is null", term.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the term {id} is null", term.Iid); + Logger.Trace("The non-nullabale shortName property of the term {id} is null", term.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.Term FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the term {id} is null", term.Iid); + Logger.Trace("The non-nullabale thingPreference property of the term {id} is null", term.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs index c88507401..ae9fbb9d1 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextParameterTypeResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the textParameterType {id} is null", textParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the textParameterType {id} is null", textParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale name property of the textParameterType {id} is null", textParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the textParameterType {id} is null", textParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the textParameterType {id} is null", textParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.TextParameterType FromJsonObject(JsonElement jsonEl { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the textParameterType {id} is null", textParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the textParameterType {id} is null", textParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs index 490706e1d..14391575e 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TextualNoteResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(contentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale content property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale content property of the textualNote {id} is null", textualNote.Iid); } else { @@ -87,7 +87,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(createdOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale createdOn property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale createdOn property of the textualNote {id} is null", textualNote.Iid); } else { @@ -115,7 +115,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(languageCodeProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale languageCode property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale languageCode property of the textualNote {id} is null", textualNote.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the textualNote {id} is null", textualNote.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale name property of the textualNote {id} is null", textualNote.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(ownerProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale owner property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale owner property of the textualNote {id} is null", textualNote.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale shortName property of the textualNote {id} is null", textualNote.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.TextualNote FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the textualNote {id} is null", textualNote.Iid); + Logger.Trace("The non-nullabale thingPreference property of the textualNote {id} is null", textualNote.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs index 218e355c7..1cea57539 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/TimeOfDayParameterTypeResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale name property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale shortName property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { @@ -163,7 +163,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(symbolProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale symbol property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale symbol property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { @@ -175,7 +175,7 @@ public static CDP4Common.DTO.TimeOfDayParameterType FromJsonObject(JsonElement j { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); + Logger.Trace("The non-nullabale thingPreference property of the timeOfDayParameterType {id} is null", timeOfDayParameterType.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs index 147ac291c..217ebd135 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitFactorResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.UnitFactor FromJsonObject(JsonElement jsonElement) { if(exponentProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale exponent property of the unitFactor {id} is null", unitFactor.Iid); + Logger.Trace("The non-nullabale exponent property of the unitFactor {id} is null", unitFactor.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.UnitFactor FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the unitFactor {id} is null", unitFactor.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the unitFactor {id} is null", unitFactor.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.UnitFactor FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the unitFactor {id} is null", unitFactor.Iid); + Logger.Trace("The non-nullabale thingPreference property of the unitFactor {id} is null", unitFactor.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.UnitFactor FromJsonObject(JsonElement jsonElement) { if(unitProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale unit property of the unitFactor {id} is null", unitFactor.Iid); + Logger.Trace("The non-nullabale unit property of the unitFactor {id} is null", unitFactor.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs index 9abd0988b..7871cf4e8 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UnitPrefixResolver.cs @@ -75,7 +75,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(conversionFactorProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale conversionFactor property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale conversionFactor property of the unitPrefix {id} is null", unitPrefix.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(isDeprecatedProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isDeprecated property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale isDeprecated property of the unitPrefix {id} is null", unitPrefix.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the unitPrefix {id} is null", unitPrefix.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale name property of the unitPrefix {id} is null", unitPrefix.Iid); } else { @@ -155,7 +155,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale shortName property of the unitPrefix {id} is null", unitPrefix.Iid); } else { @@ -167,7 +167,7 @@ public static CDP4Common.DTO.UnitPrefix FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the unitPrefix {id} is null", unitPrefix.Iid); + Logger.Trace("The non-nullabale thingPreference property of the unitPrefix {id} is null", unitPrefix.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs index 5a3ec842c..20bea1856 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserPreferenceResolver.cs @@ -83,7 +83,7 @@ public static CDP4Common.DTO.UserPreference FromJsonObject(JsonElement jsonEleme { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the userPreference {id} is null", userPreference.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the userPreference {id} is null", userPreference.Iid); } else { @@ -95,7 +95,7 @@ public static CDP4Common.DTO.UserPreference FromJsonObject(JsonElement jsonEleme { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the userPreference {id} is null", userPreference.Iid); + Logger.Trace("The non-nullabale shortName property of the userPreference {id} is null", userPreference.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.UserPreference FromJsonObject(JsonElement jsonEleme { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the userPreference {id} is null", userPreference.Iid); + Logger.Trace("The non-nullabale thingPreference property of the userPreference {id} is null", userPreference.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.UserPreference FromJsonObject(JsonElement jsonEleme { if(valueProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale value property of the userPreference {id} is null", userPreference.Iid); + Logger.Trace("The non-nullabale value property of the userPreference {id} is null", userPreference.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs index 55801be0e..d5edbfa43 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/UserRuleVerificationResolver.cs @@ -95,7 +95,7 @@ public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jso { if(isActiveProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale isActive property of the userRuleVerification {id} is null", userRuleVerification.Iid); + Logger.Trace("The non-nullabale isActive property of the userRuleVerification {id} is null", userRuleVerification.Iid); } else { @@ -107,7 +107,7 @@ public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jso { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the userRuleVerification {id} is null", userRuleVerification.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the userRuleVerification {id} is null", userRuleVerification.Iid); } else { @@ -119,7 +119,7 @@ public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jso { if(ruleProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale rule property of the userRuleVerification {id} is null", userRuleVerification.Iid); + Logger.Trace("The non-nullabale rule property of the userRuleVerification {id} is null", userRuleVerification.Iid); } else { @@ -131,7 +131,7 @@ public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jso { if(statusProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale status property of the userRuleVerification {id} is null", userRuleVerification.Iid); + Logger.Trace("The non-nullabale status property of the userRuleVerification {id} is null", userRuleVerification.Iid); } else { @@ -143,7 +143,7 @@ public static CDP4Common.DTO.UserRuleVerification FromJsonObject(JsonElement jso { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the userRuleVerification {id} is null", userRuleVerification.Iid); + Logger.Trace("The non-nullabale thingPreference property of the userRuleVerification {id} is null", userRuleVerification.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs b/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs index 8fe97a0b4..b7cb379dd 100644 --- a/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs +++ b/CDP4JsonSerializer/AutoGenDtoDeserializer/ValueGroupResolver.cs @@ -115,7 +115,7 @@ public static CDP4Common.DTO.ValueGroup FromJsonObject(JsonElement jsonElement) { if(modifiedOnProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale modifiedOn property of the valueGroup {id} is null", valueGroup.Iid); + Logger.Trace("The non-nullabale modifiedOn property of the valueGroup {id} is null", valueGroup.Iid); } else { @@ -127,7 +127,7 @@ public static CDP4Common.DTO.ValueGroup FromJsonObject(JsonElement jsonElement) { if(nameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale name property of the valueGroup {id} is null", valueGroup.Iid); + Logger.Trace("The non-nullabale name property of the valueGroup {id} is null", valueGroup.Iid); } else { @@ -139,7 +139,7 @@ public static CDP4Common.DTO.ValueGroup FromJsonObject(JsonElement jsonElement) { if(shortNameProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale shortName property of the valueGroup {id} is null", valueGroup.Iid); + Logger.Trace("The non-nullabale shortName property of the valueGroup {id} is null", valueGroup.Iid); } else { @@ -151,7 +151,7 @@ public static CDP4Common.DTO.ValueGroup FromJsonObject(JsonElement jsonElement) { if(thingPreferenceProperty.ValueKind == JsonValueKind.Null) { - Logger.Debug("The non-nullabale thingPreference property of the valueGroup {id} is null", valueGroup.Iid); + Logger.Trace("The non-nullabale thingPreference property of the valueGroup {id} is null", valueGroup.Iid); } else { diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs index 50c743b8a..1084b3f83 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActionItemSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,459 +51,437 @@ namespace CDP4JsonSerializer public class ActionItemSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ActionItem actionItem) + { + throw new ArgumentException("The thing shall be a ActionItem", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actionee": - var allowedVersionsForActionee = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ActionItem since Version is below 1.1.0"); + return; + } - if(!allowedVersionsForActionee.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ActionItem for Version 1.1.0"); writer.WritePropertyName("actionee"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStringValue(actionItem.Actionee); + writer.WriteStartArray("approvedBy"u8); + + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(approvedByItem); } - break; - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ActionItem for Version 1.2.0"); + writer.WritePropertyName("actionee"u8); + writer.WriteStringValue(actionItem.Actionee); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "closeoutdate": - var allowedVersionsForCloseOutDate = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForCloseOutDate.Contains(requestedVersion)) + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("closeOutDate"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "closeoutstatement": - var allowedVersionsForCloseOutStatement = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForCloseOutStatement.Contains(requestedVersion)) + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("closeOutStatement"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); + writer.WriteStringValue(sourceAnnotationItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actionItem.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ActionItem for Version 1.3.0"); + writer.WritePropertyName("actionee"u8); + writer.WriteStringValue(actionItem.Actionee); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("createdOn"u8); - - if(value != null) + if(actionItem.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(actionItem.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WriteStartArray("discussion"u8); - - if(value is IEnumerable objectListDiscussion) - { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - } - writer.WriteEndArray(); - break; - case "duedate": - var allowedVersionsForDueDate = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(actionItem.Author); + writer.WriteStartArray("category"u8); - if(!allowedVersionsForDueDate.Contains(requestedVersion)) + foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("dueDate"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(actionItem.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actionItem.ClassKind.ToString()); + writer.WritePropertyName("closeOutDate"u8); + + if(actionItem.CloseOutDate.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("closeOutStatement"u8); + writer.WriteStringValue(actionItem.CloseOutStatement); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(actionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("dueDate"u8); + writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(actionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(actionItem.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(actionItem.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WritePropertyName("languageCode"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actionItem.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(actionItem.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(sourceAnnotationItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(actionItem.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actionItem.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(actionItem.Title); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actionee": + if(!AllowedVersionsPerProperty["actionee"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("actionee"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { @@ -510,20 +489,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -535,20 +507,31 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("author"u8); if(value != null) { @@ -560,49 +543,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("relatedThing"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListRelatedThing) + if(value is IEnumerable objectListCategory) { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(relatedThingItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -610,24 +579,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -635,49 +597,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + case "closeoutdate": + if(!AllowedVersionsPerProperty["closeOutDate"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); - - if(value is IEnumerable objectListSourceAnnotation) + writer.WritePropertyName("closeOutDate"u8); + + if(value != null) { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - break; - case "status": - var allowedVersionsForStatus = new List + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForStatus.Contains(requestedVersion)) + break; + case "closeoutstatement": + if(!AllowedVersionsPerProperty["closeOutStatement"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("status"u8); + writer.WritePropertyName("closeOutStatement"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue((string)value); } else { @@ -685,19 +633,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("content"u8); if(value != null) { @@ -709,24 +651,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -734,396 +669,332 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ActionItem"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ActionItem actionItem) - { - throw new ArgumentException("The thing shall be a ActionItem", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ActionItem since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.1.0"); - writer.WritePropertyName("actionee"u8); - writer.WriteStringValue(actionItem.Actionee); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { - writer.WriteStringValue(approvedByItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(actionItem.Author); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("discussion"u8); - foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDiscussion) { - writer.WriteStringValue(categoryItem); + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(actionItem.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actionItem.ClassKind.ToString()); - writer.WritePropertyName("closeOutDate"u8); + break; + case "duedate": + if(!AllowedVersionsPerProperty["dueDate"].Contains(requestedVersion)) + { + return; + } - if(actionItem.CloseOutDate.HasValue) + writer.WritePropertyName("dueDate"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("closeOutStatement"u8); - writer.WriteStringValue(actionItem.CloseOutStatement); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(actionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("dueDate"u8); - writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(actionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(actionItem.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(actionItem.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actionItem.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(actionItem.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("languageCode"u8); + + if(value != null) { - writer.WriteStringValue(sourceAnnotationItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(actionItem.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(actionItem.Title); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.2.0"); - writer.WritePropertyName("actionee"u8); - writer.WriteStringValue(actionItem.Actionee); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(approvedByItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(actionItem.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(actionItem.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actionItem.ClassKind.ToString()); - writer.WritePropertyName("closeOutDate"u8); - - if(actionItem.CloseOutDate.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("closeOutStatement"u8); - writer.WriteStringValue(actionItem.CloseOutStatement); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(actionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("dueDate"u8); - writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(actionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(actionItem.Owner); writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(actionItem.PrimaryAnnotatedThing.HasValue) + + if(value != null) { - writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actionItem.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(actionItem.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(actionItem.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(actionItem.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(actionItem.Title); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ActionItem for Version 1.3.0"); - writer.WritePropertyName("actionee"u8); - writer.WriteStringValue(actionItem.Actionee); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(actionItem.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in actionItem.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(actionItem.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in actionItem.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(actionItem.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actionItem.ClassKind.ToString()); - writer.WritePropertyName("closeOutDate"u8); - - if(actionItem.CloseOutDate.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.CloseOutDate.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("closeOutStatement"u8); - writer.WriteStringValue(actionItem.CloseOutStatement); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(actionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(actionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in actionItem.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("dueDate"u8); - writer.WriteStringValue(actionItem.DueDate.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("sourceAnnotation"u8); - foreach(var excludedDomainItem in actionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(excludedDomainItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in actionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(actionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(actionItem.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(actionItem.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(actionItem.PrimaryAnnotatedThing.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in actionItem.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actionItem.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(actionItem.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var sourceAnnotationItem in actionItem.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(sourceAnnotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(actionItem.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(actionItem.ThingPreference); writer.WritePropertyName("title"u8); - writer.WriteStringValue(actionItem.Title); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ActionItem"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actionee", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "closeOutDate", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "closeOutStatement", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "dueDate", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs index c7484c138..b111405a9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateListSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,328 +50,6 @@ namespace CDP4JsonSerializer /// public class ActualFiniteStateListSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "actualstate": - var allowedVersionsForActualState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForActualState.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("actualState"u8); - - if(value is IEnumerable objectListActualState) - { - foreach(var actualStateItem in objectListActualState.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(actualStateItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeoption": - var allowedVersionsForExcludeOption = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludeOption.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludeOption"u8); - - if(value is IEnumerable objectListExcludeOption) - { - foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludeOptionItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("owner"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "possiblefinitestatelist": - var allowedVersionsForPossibleFiniteStateList = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPossibleFiniteStateList.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("possibleFiniteStateList"u8); - - if(value is IEnumerable objectListPossibleFiniteStateList) - { - foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(possibleFiniteStateListItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ActualFiniteStateList"); - } - } - /// /// Serializes a into an /// @@ -397,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteStateList for Version 1.0.0"); writer.WriteStartArray("actualState"u8); foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) @@ -406,6 +85,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); writer.WriteStartArray("excludeOption"u8); @@ -416,6 +96,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(actualFiniteStateList.Iid); writer.WritePropertyName("owner"u8); @@ -428,11 +109,12 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteStateList for Version 1.1.0"); writer.WriteStartArray("actualState"u8); foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) @@ -441,6 +123,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -451,6 +134,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -459,6 +143,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) @@ -467,6 +152,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(actualFiniteStateList.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -481,11 +167,12 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteStateList for Version 1.2.0"); writer.WriteStartArray("actualState"u8); foreach(var actualStateItem in actualFiniteStateList.ActualState.OrderBy(x => x, this.GuidComparer)) @@ -494,6 +181,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -504,6 +192,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -512,6 +201,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) @@ -520,6 +210,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(actualFiniteStateList.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -534,13 +225,14 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); writer.WritePropertyName("thingPreference"u8); writer.WriteStringValue(actualFiniteStateList.ThingPreference); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteStateList for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteStateList for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(actualFiniteStateList.Actor.HasValue) @@ -560,6 +252,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(actualFiniteStateList.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -570,6 +263,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in actualFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -578,6 +272,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); foreach(var excludeOptionItem in actualFiniteStateList.ExcludeOption.OrderBy(x => x, this.GuidComparer)) @@ -586,6 +281,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(actualFiniteStateList.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -600,6 +296,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(actualFiniteStateList.RevisionNumber); writer.WritePropertyName("thingPreference"u8); @@ -611,6 +308,260 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualstate": + if(!AllowedVersionsPerProperty["actualState"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("actualState"u8); + + if(value is IEnumerable objectListActualState) + { + foreach(var actualStateItem in objectListActualState.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualStateItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeoption": + if(!AllowedVersionsPerProperty["excludeOption"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludeOption"u8); + + if(value is IEnumerable objectListExcludeOption) + { + foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "possiblefinitestatelist": + if(!AllowedVersionsPerProperty["possibleFiniteStateList"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("possibleFiniteStateList"u8); + + if(value is IEnumerable objectListPossibleFiniteStateList) + { + foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleFiniteStateListItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ActualFiniteStateList"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "actualState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludeOption", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleFiniteStateList", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs index 0f93c24da..f5addebc0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ActualFiniteStateSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,193 @@ namespace CDP4JsonSerializer /// public class ActualFiniteStateSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ActualFiniteState actualFiniteState) + { + throw new ArgumentException("The thing shall be a ActualFiniteState", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ActualFiniteState since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteState for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteState for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteState for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteState.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ActualFiniteState for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(actualFiniteState.Actor.HasValue) + { + writer.WriteStringValue(actualFiniteState.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(actualFiniteState.Iid); + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(actualFiniteState.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("possibleState"u8); + + foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleStateItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(actualFiniteState.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(actualFiniteState.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +244,7 @@ public class ActualFiniteStateSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +252,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +270,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,15 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "kind": - var allowedVersionsForKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["kind"].Contains(requestedVersion)) { return; } @@ -214,14 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +378,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "possiblestate": - var allowedVersionsForPossibleState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPossibleState.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["possibleState"].Contains(requestedVersion)) { return; } @@ -265,15 +396,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +414,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -320,181 +437,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ActualFiniteState actualFiniteState) - { - throw new ArgumentException("The thing shall be a ActualFiniteState", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ActualFiniteState since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actualFiniteState.Iid); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(actualFiniteState.Kind.ToString()); - writer.WriteStartArray("possibleState"u8); - - foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleStateItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actualFiniteState.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actualFiniteState.Iid); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(actualFiniteState.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("possibleState"u8); - - foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleStateItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actualFiniteState.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actualFiniteState.Iid); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(actualFiniteState.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("possibleState"u8); - - foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleStateItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actualFiniteState.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(actualFiniteState.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ActualFiniteState for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(actualFiniteState.Actor.HasValue) - { - writer.WriteStringValue(actualFiniteState.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(actualFiniteState.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in actualFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in actualFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(actualFiniteState.Iid); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(actualFiniteState.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(actualFiniteState.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("possibleState"u8); - - foreach(var possibleStateItem in actualFiniteState.PossibleState.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleStateItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(actualFiniteState.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(actualFiniteState.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "kind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs index 250910dbe..f9f993a00 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/AliasSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class AliasSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Alias alias) + { + throw new ArgumentException("The thing shall be a Alias", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Alias since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Alias for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Alias for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Alias for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(alias.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Alias for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(alias.Actor.HasValue) + { + writer.WriteStringValue(alias.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(alias.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(alias.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(alias.Iid); + writer.WritePropertyName("isSynonym"u8); + writer.WriteBooleanValue(alias.IsSynonym); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(alias.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(alias.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(alias.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class AliasSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -138,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "issynonym": - var allowedVersionsForIsSynonym = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsSynonym.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isSynonym"].Contains(requestedVersion)) { return; } @@ -240,15 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -266,14 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -291,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Alias alias) - { - throw new ArgumentException("The thing shall be a Alias", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Alias since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(alias.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(alias.Content); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(alias.Iid); - writer.WritePropertyName("isSynonym"u8); - writer.WriteBooleanValue(alias.IsSynonym); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(alias.LanguageCode); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(alias.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(alias.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(alias.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(alias.Iid); - writer.WritePropertyName("isSynonym"u8); - writer.WriteBooleanValue(alias.IsSynonym); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(alias.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(alias.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(alias.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(alias.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(alias.Iid); - writer.WritePropertyName("isSynonym"u8); - writer.WriteBooleanValue(alias.IsSynonym); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(alias.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(alias.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(alias.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Alias for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(alias.Actor.HasValue) - { - writer.WriteStringValue(alias.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(alias.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(alias.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in alias.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in alias.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(alias.Iid); - writer.WritePropertyName("isSynonym"u8); - writer.WriteBooleanValue(alias.IsSynonym); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(alias.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(alias.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(alias.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(alias.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isSynonym", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs index 6b7bbe8aa..cba482db8 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/AndExpressionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,185 @@ namespace CDP4JsonSerializer /// public class AndExpressionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not AndExpression andExpression) + { + throw new ArgumentException("The thing shall be a AndExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of AndExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing AndExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing AndExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing AndExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(andExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing AndExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(andExpression.Actor.HasValue) + { + writer.WriteStringValue(andExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(andExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(andExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(andExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(andExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +236,7 @@ public class AndExpressionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +244,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +298,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +316,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +334,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +352,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +370,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "term": - var allowedVersionsForTerm = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTerm.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["term"].Contains(requestedVersion)) { return; } @@ -265,13 +388,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -294,173 +411,20 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not AndExpression andExpression) - { - throw new ArgumentException("The thing shall be a AndExpression", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of AndExpression since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(andExpression.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(andExpression.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(andExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(andExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(andExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(andExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(andExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(andExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(andExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(andExpression.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing AndExpression for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(andExpression.Actor.HasValue) - { - writer.WriteStringValue(andExpression.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(andExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in andExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in andExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(andExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(andExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(andExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in andExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(andExpression.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "term", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs index 39477bf3f..c05f4dd9d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ApprovalSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,176 @@ namespace CDP4JsonSerializer /// public class ApprovalSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Approval approval) + { + throw new ArgumentException("The thing shall be a Approval", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Approval since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Approval for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Approval for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(approval.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Approval for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(approval.Actor.HasValue) + { + writer.WriteStringValue(approval.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(approval.Author); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(approval.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(approval.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(approval.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(approval.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(approval.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(approval.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(approval.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(approval.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +227,7 @@ public class ApprovalSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +235,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +253,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +271,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassification.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } @@ -136,14 +289,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -161,14 +307,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -186,14 +325,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -211,14 +343,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -236,14 +361,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -261,14 +379,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +397,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -311,14 +415,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -336,14 +433,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -361,14 +451,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -386,13 +469,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,168 +492,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Approval approval) - { - throw new ArgumentException("The thing shall be a Approval", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Approval since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(approval.Author); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(approval.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(approval.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(approval.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(approval.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(approval.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(approval.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(approval.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(approval.Author); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(approval.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(approval.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(approval.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(approval.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(approval.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(approval.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(approval.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(approval.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Approval for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(approval.Actor.HasValue) - { - writer.WriteStringValue(approval.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(approval.Author); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(approval.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(approval.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(approval.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(approval.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in approval.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in approval.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(approval.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(approval.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(approval.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(approval.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(approval.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(approval.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs index ee7e3e433..99a8b199c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ArrayParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,421 +51,437 @@ namespace CDP4JsonSerializer public class ArrayParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ArrayParameterType arrayParameterType) + { + throw new ArgumentException("The thing shall be a ArrayParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ArrayParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ArrayParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(componentItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("dimension"u8); - if(value is IEnumerable objectListAlias) + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteOrderedItem(dimensionItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ArrayParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(componentItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "component": - var allowedVersionsForComponent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("dimension"u8); - if(!allowedVersionsForComponent.Contains(requestedVersion)) + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(dimensionItem); } - writer.WriteStartArray("component"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListComponent) + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(componentItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); break; - case "dimension": - var allowedVersionsForDimension = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ArrayParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDimension.Contains(requestedVersion)) + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("dimension"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDimension) + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var dimensionItem in objectListDimension.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(dimensionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(componentItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("dimension"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(dimensionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(arrayParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ArrayParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(arrayParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(arrayParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "isfinalized": - var allowedVersionsForIsFinalized = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); - if(!allowedVersionsForIsFinalized.Contains(requestedVersion)) + foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(componentItem); } - writer.WritePropertyName("isFinalized"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "istensor": - var allowedVersionsForIsTensor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("dimension"u8); - if(!allowedVersionsForIsTensor.Contains(requestedVersion)) + foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(dimensionItem); } - writer.WritePropertyName("isTensor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(arrayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(arrayParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(arrayParameterType.IsFinalized); + writer.WritePropertyName("isTensor"u8); + writer.WriteBooleanValue(arrayParameterType.IsTensor); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(arrayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(arrayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(arrayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(arrayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(arrayParameterType.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForName.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -472,77 +489,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) { - writer.WriteNullValue(); + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } } - + + writer.WriteEndArray(); break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -550,411 +543,325 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "component": + if(!AllowedVersionsPerProperty["component"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("component"u8); + + if(value is IEnumerable objectListComponent) { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); + foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } } - + + writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ArrayParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ArrayParameterType arrayParameterType) - { - throw new ArgumentException("The thing shall be a ArrayParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ArrayParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("definition"u8); - foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(categoryItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "dimension": + if(!AllowedVersionsPerProperty["dimension"].Contains(requestedVersion)) { - writer.WriteOrderedItem(componentItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("dimension"u8); - foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDimension) { - writer.WriteStringValue(definitionItem); + foreach(var dimensionItem in objectListDimension.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dimensionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("dimension"u8); - - foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteOrderedItem(dimensionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(hyperLinkItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(arrayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(arrayParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(arrayParameterType.IsFinalized); - writer.WritePropertyName("isTensor"u8); - writer.WriteBooleanValue(arrayParameterType.IsTensor); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(arrayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(arrayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(arrayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(arrayParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteOrderedItem(componentItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("dimension"u8); - - foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteOrderedItem(dimensionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(arrayParameterType.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(arrayParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(arrayParameterType.IsFinalized); - writer.WritePropertyName("isTensor"u8); - writer.WriteBooleanValue(arrayParameterType.IsTensor); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(arrayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(arrayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(arrayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(arrayParameterType.Symbol); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "isfinalized": + if(!AllowedVersionsPerProperty["isFinalized"].Contains(requestedVersion)) { - writer.WriteOrderedItem(componentItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isFinalized"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("dimension"u8); - - foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(dimensionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "istensor": + if(!AllowedVersionsPerProperty["isTensor"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isTensor"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(arrayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(arrayParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(arrayParameterType.IsFinalized); - writer.WritePropertyName("isTensor"u8); - writer.WriteBooleanValue(arrayParameterType.IsTensor); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(arrayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(arrayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(arrayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(arrayParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(arrayParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ArrayParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(arrayParameterType.Actor.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(arrayParameterType.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in arrayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in arrayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(arrayParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in arrayParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(componentItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in arrayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("dimension"u8); - - foreach(var dimensionItem in arrayParameterType.Dimension.OrderBy(x => x, this.OrderedItemComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteOrderedItem(dimensionItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in arrayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var excludedPersonItem in arrayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WritePropertyName("symbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var hyperLinkItem in arrayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(arrayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(arrayParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(arrayParameterType.IsFinalized); - writer.WritePropertyName("isTensor"u8); - writer.WriteBooleanValue(arrayParameterType.IsTensor); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(arrayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(arrayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(arrayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(arrayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(arrayParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(arrayParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ArrayParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "component", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "dimension", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isFinalized", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isTensor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs index d908fa88d..4547107d4 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryNoteSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,203 @@ namespace CDP4JsonSerializer /// public class BinaryNoteSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not BinaryNote binaryNote) + { + throw new ArgumentException("The thing shall be a BinaryNote", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryNote for Version 1.1.0"); + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryNote for Version 1.2.0"); + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryNote.Actor.HasValue) + { + writer.WriteStringValue(binaryNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("caption"u8); + writer.WriteStringValue(binaryNote.Caption); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryNote.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("fileType"u8); + writer.WriteStringValue(binaryNote.FileType); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryNote.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +254,7 @@ public class BinaryNoteSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "caption": - var allowedVersionsForCaption = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCaption.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["caption"].Contains(requestedVersion)) { return; } @@ -111,14 +298,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -136,14 +316,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -161,14 +334,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +352,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +370,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +388,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "filetype": - var allowedVersionsForFileType = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFileType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["fileType"].Contains(requestedVersion)) { return; } @@ -261,14 +406,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +424,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +442,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -336,14 +460,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -361,14 +478,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -386,14 +496,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -411,13 +514,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -440,192 +537,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not BinaryNote binaryNote) - { - throw new ArgumentException("The thing shall be a BinaryNote", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of BinaryNote since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.1.0"); - writer.WritePropertyName("caption"u8); - writer.WriteStringValue(binaryNote.Caption); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryNote.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("fileType"u8); - writer.WriteStringValue(binaryNote.FileType); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryNote.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryNote.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.2.0"); - writer.WritePropertyName("caption"u8); - writer.WriteStringValue(binaryNote.Caption); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryNote.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("fileType"u8); - writer.WriteStringValue(binaryNote.FileType); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryNote.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryNote.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryNote.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryNote for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(binaryNote.Actor.HasValue) - { - writer.WriteStringValue(binaryNote.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("caption"u8); - writer.WriteStringValue(binaryNote.Caption); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryNote.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(binaryNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("fileType"u8); - writer.WriteStringValue(binaryNote.FileType); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryNote.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryNote.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryNote.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "caption", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fileType", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs index 68c5bc3ee..79fbf3310 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipRuleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,266 +51,345 @@ namespace CDP4JsonSerializer public class BinaryRelationshipRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not BinaryRelationshipRule binaryRelationshipRule) + { + throw new ArgumentException("The thing shall be a BinaryRelationshipRule", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationshipRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationshipRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationshipRule for Version 1.1.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationshipRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "forwardrelationshipname": - var allowedVersionsForForwardRelationshipName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForForwardRelationshipName.Contains(requestedVersion)) + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationshipRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationshipRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryRelationshipRule.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(binaryRelationshipRule.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("forwardRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationshipRule.Iid); + writer.WritePropertyName("inverseRelationshipName"u8); + writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationshipRule.Name); + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(binaryRelationshipRule.ShortName); + writer.WritePropertyName("sourceCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.SourceCategory); + writer.WritePropertyName("targetCategory"u8); + writer.WriteStringValue(binaryRelationshipRule.TargetCategory); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationshipRule.ThingPreference); break; - case "inverserelationshipname": - var allowedVersionsForInverseRelationshipName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForInverseRelationshipName.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("inverseRelationshipName"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -317,25 +397,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("isDeprecated"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -343,46 +433,67 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); break; - case "name": - var allowedVersionsForName = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForName.Contains(requestedVersion)) + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "forwardrelationshipname": + if(!AllowedVersionsPerProperty["forwardRelationshipName"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("forwardRelationshipName"u8); if(value != null) { @@ -394,21 +505,31 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relationshipcategory": - var allowedVersionsForRelationshipCategory = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForRelationshipCategory.Contains(requestedVersion)) + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("relationshipCategory"u8); + writer.WritePropertyName("iid"u8); if(value != null) { @@ -420,25 +541,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "inverserelationshipname": + if(!AllowedVersionsPerProperty["inverseRelationshipName"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("inverseRelationshipName"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((string)value); } else { @@ -446,25 +559,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -472,25 +577,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "sourcecategory": - var allowedVersionsForSourceCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSourceCategory.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("sourceCategory"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -498,25 +595,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "targetcategory": - var allowedVersionsForTargetCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTargetCategory.Contains(requestedVersion)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("targetCategory"u8); + writer.WritePropertyName("name"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -524,23 +613,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "relationshipcategory": + if(!AllowedVersionsPerProperty["relationshipCategory"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("relationshipCategory"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -548,307 +631,126 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the BinaryRelationshipRule"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not BinaryRelationshipRule binaryRelationshipRule) - { - throw new ArgumentException("The thing shall be a BinaryRelationshipRule", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationshipRule since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("forwardRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationshipRule.Iid); - writer.WritePropertyName("inverseRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationshipRule.Name); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryRelationshipRule.ShortName); - writer.WritePropertyName("sourceCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.SourceCategory); - writer.WritePropertyName("targetCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.TargetCategory); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("forwardRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationshipRule.Iid); - writer.WritePropertyName("inverseRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationshipRule.Name); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryRelationshipRule.ShortName); - writer.WritePropertyName("sourceCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.SourceCategory); - writer.WritePropertyName("targetCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.TargetCategory); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + case "sourcecategory": + if(!AllowedVersionsPerProperty["sourceCategory"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("sourceCategory"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("forwardRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "targetcategory": + if(!AllowedVersionsPerProperty["targetCategory"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationshipRule.Iid); - writer.WritePropertyName("inverseRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationshipRule.Name); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryRelationshipRule.ShortName); - writer.WritePropertyName("sourceCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.SourceCategory); writer.WritePropertyName("targetCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.TargetCategory); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryRelationshipRule.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationshipRule for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(binaryRelationshipRule.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(binaryRelationshipRule.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in binaryRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in binaryRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("forwardRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.ForwardRelationshipName); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in binaryRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationshipRule.Iid); - writer.WritePropertyName("inverseRelationshipName"u8); - writer.WriteStringValue(binaryRelationshipRule.InverseRelationshipName); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(binaryRelationshipRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationshipRule.Name); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(binaryRelationshipRule.ShortName); - writer.WritePropertyName("sourceCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.SourceCategory); - writer.WritePropertyName("targetCategory"u8); - writer.WriteStringValue(binaryRelationshipRule.TargetCategory); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryRelationshipRule.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the BinaryRelationshipRule"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "forwardRelationshipName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "inverseRelationshipName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "relationshipCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "targetCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs index f7c686f76..a719d0883 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BinaryRelationshipSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,240 @@ namespace CDP4JsonSerializer /// public class BinaryRelationshipSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not BinaryRelationship binaryRelationship) + { + throw new ArgumentException("The thing shall be a BinaryRelationship", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationship since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationship for Version 1.0.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationship for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationship for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationship.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing BinaryRelationship for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(binaryRelationship.Actor.HasValue) + { + writer.WriteStringValue(binaryRelationship.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(binaryRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(binaryRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(binaryRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(binaryRelationship.RevisionNumber); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(binaryRelationship.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(binaryRelationship.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(binaryRelationship.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +291,7 @@ public class BinaryRelationshipSerializer : BaseThingSerializer, IThingSerialize /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +299,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +317,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -112,15 +335,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -138,14 +353,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +371,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +389,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +407,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,13 +425,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -263,15 +443,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -289,14 +461,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametervalue": - var allowedVersionsForParameterValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterValue"].Contains(requestedVersion)) { return; } @@ -314,15 +479,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -340,15 +497,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "source": - var allowedVersionsForSource = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSource.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["source"].Contains(requestedVersion)) { return; } @@ -366,15 +515,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "target": - var allowedVersionsForTarget = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTarget.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["target"].Contains(requestedVersion)) { return; } @@ -392,13 +533,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -421,225 +556,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not BinaryRelationship binaryRelationship) - { - throw new ArgumentException("The thing shall be a BinaryRelationship", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of BinaryRelationship since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.0.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationship.Iid); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryRelationship.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationship.RevisionNumber); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(binaryRelationship.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(binaryRelationship.Target); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationship.RevisionNumber); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(binaryRelationship.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(binaryRelationship.Target); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationship.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationship.RevisionNumber); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(binaryRelationship.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(binaryRelationship.Target); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryRelationship.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing BinaryRelationship for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(binaryRelationship.Actor.HasValue) - { - writer.WriteStringValue(binaryRelationship.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in binaryRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(binaryRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in binaryRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in binaryRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(binaryRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(binaryRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(binaryRelationship.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(binaryRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in binaryRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(binaryRelationship.RevisionNumber); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(binaryRelationship.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(binaryRelationship.Target); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(binaryRelationship.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "source", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "target", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs index 55e95e544..abc6c6d35 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BookSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,218 @@ namespace CDP4JsonSerializer /// public class BookSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Book book) + { + throw new ArgumentException("The thing shall be a Book", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Book since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Book for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Book for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(book.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Book for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(book.Actor.HasValue) + { + writer.WriteStringValue(book.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(book.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(book.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(book.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(book.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(book.RevisionNumber); + writer.WriteStartArray("section"u8); + + foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(sectionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(book.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(book.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +269,7 @@ public class BookSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +277,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +295,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -111,14 +313,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +331,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -161,14 +349,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -186,14 +367,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -211,14 +385,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -236,14 +403,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -261,14 +421,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -286,14 +439,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -311,14 +457,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -336,14 +475,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "section": - var allowedVersionsForSection = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSection.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["section"].Contains(requestedVersion)) { return; } @@ -361,14 +493,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +511,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,204 +534,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Book book) - { - throw new ArgumentException("The thing shall be a Book", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Book since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(book.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(book.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(book.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(book.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(book.RevisionNumber); - writer.WriteStartArray("section"u8); - - foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(sectionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(book.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(book.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(book.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(book.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(book.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(book.RevisionNumber); - writer.WriteStartArray("section"u8); - - foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(sectionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(book.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(book.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Book for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(book.Actor.HasValue) - { - writer.WriteStringValue(book.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in book.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(book.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(book.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in book.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in book.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(book.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(book.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(book.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(book.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(book.RevisionNumber); - writer.WriteStartArray("section"u8); - - foreach(var sectionItem in book.Section.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(sectionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(book.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(book.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "section", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs index 8bd6e5c00..60566d570 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BooleanParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,349 @@ namespace CDP4JsonSerializer public class BooleanParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not BooleanParameterType booleanParameterType) + { + throw new ArgumentException("The thing shall be a BooleanParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of BooleanParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing BooleanParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing BooleanParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing BooleanParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(booleanParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing BooleanParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(booleanParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(booleanParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(booleanParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(booleanParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(booleanParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(booleanParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(booleanParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(booleanParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(booleanParameterType.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the BooleanParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not BooleanParameterType booleanParameterType) - { - throw new ArgumentException("The thing shall be a BooleanParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of BooleanParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(booleanParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(booleanParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(booleanParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(booleanParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(booleanParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(booleanParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(booleanParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(booleanParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(booleanParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(booleanParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(booleanParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(booleanParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(booleanParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(booleanParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(booleanParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(booleanParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(booleanParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(booleanParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(booleanParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing BooleanParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(booleanParameterType.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(booleanParameterType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in booleanParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in booleanParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(booleanParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in booleanParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in booleanParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in booleanParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in booleanParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(booleanParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(booleanParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(booleanParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(booleanParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(booleanParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(booleanParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(booleanParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(booleanParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the BooleanParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs index f7d66e3c9..a20241ef0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BoundsSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,170 @@ namespace CDP4JsonSerializer /// public class BoundsSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Bounds bounds) + { + throw new ArgumentException("The thing shall be a Bounds", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Bounds since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Bounds for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Bounds for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(bounds.ThingPreference); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Bounds for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(bounds.Actor.HasValue) + { + writer.WriteStringValue(bounds.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(bounds.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("height"u8); + writer.WriteNumberValue(bounds.Height); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(bounds.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(bounds.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(bounds.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(bounds.ThingPreference); + writer.WritePropertyName("width"u8); + writer.WriteNumberValue(bounds.Width); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(bounds.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(bounds.Y); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +221,7 @@ public class BoundsSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +229,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +247,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +265,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "height": - var allowedVersionsForHeight = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHeight.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["height"].Contains(requestedVersion)) { return; } @@ -186,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -211,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -236,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -261,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -286,13 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -310,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "width": - var allowedVersionsForWidth = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForWidth.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["width"].Contains(requestedVersion)) { return; } @@ -335,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "x": - var allowedVersionsForX = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForX.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["x"].Contains(requestedVersion)) { return; } @@ -360,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "y": - var allowedVersionsForY = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForY.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["y"].Contains(requestedVersion)) { return; } @@ -390,162 +468,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Bounds bounds) - { - throw new ArgumentException("The thing shall be a Bounds", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Bounds since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(bounds.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("height"u8); - writer.WriteNumberValue(bounds.Height); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(bounds.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(bounds.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(bounds.RevisionNumber); - writer.WritePropertyName("width"u8); - writer.WriteNumberValue(bounds.Width); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(bounds.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(bounds.Y); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(bounds.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("height"u8); - writer.WriteNumberValue(bounds.Height); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(bounds.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(bounds.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(bounds.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(bounds.ThingPreference); - writer.WritePropertyName("width"u8); - writer.WriteNumberValue(bounds.Width); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(bounds.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(bounds.Y); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Bounds for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(bounds.Actor.HasValue) - { - writer.WriteStringValue(bounds.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(bounds.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in bounds.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in bounds.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("height"u8); - writer.WriteNumberValue(bounds.Height); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(bounds.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(bounds.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(bounds.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(bounds.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(bounds.ThingPreference); - writer.WritePropertyName("width"u8); - writer.WriteNumberValue(bounds.Width); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(bounds.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(bounds.Y); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "height", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "width", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "x", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "y", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs index bbcf92878..9ae30150d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/BuiltInRuleVerificationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,253 @@ namespace CDP4JsonSerializer /// public class BuiltInRuleVerificationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not BuiltInRuleVerification builtInRuleVerification) + { + throw new ArgumentException("The thing shall be a BuiltInRuleVerification", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of BuiltInRuleVerification since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing BuiltInRuleVerification for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing BuiltInRuleVerification for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing BuiltInRuleVerification for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(builtInRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing BuiltInRuleVerification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(builtInRuleVerification.Actor.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(builtInRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(builtInRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(builtInRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(builtInRuleVerification.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(builtInRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(builtInRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +304,7 @@ public class BuiltInRuleVerificationSerializer : BaseThingSerializer, IThingSeri /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +312,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +330,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +348,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +366,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +384,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "executedon": - var allowedVersionsForExecutedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExecutedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["executedOn"].Contains(requestedVersion)) { return; } @@ -188,15 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +420,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isactive": - var allowedVersionsForIsActive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsActive.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isActive"].Contains(requestedVersion)) { return; } @@ -240,14 +438,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +456,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -291,15 +474,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,15 +492,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "status": - var allowedVersionsForStatus = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { return; } @@ -343,13 +510,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -367,15 +528,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "violation": - var allowedVersionsForViolation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForViolation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["violation"].Contains(requestedVersion)) { return; } @@ -398,241 +551,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not BuiltInRuleVerification builtInRuleVerification) - { - throw new ArgumentException("The thing shall be a BuiltInRuleVerification", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of BuiltInRuleVerification since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); - writer.WritePropertyName("executedOn"u8); - - if(builtInRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(builtInRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(builtInRuleVerification.IsActive); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(builtInRuleVerification.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(builtInRuleVerification.Status.ToString()); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(builtInRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(builtInRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(builtInRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(builtInRuleVerification.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(builtInRuleVerification.Status.ToString()); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(builtInRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(builtInRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(builtInRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(builtInRuleVerification.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(builtInRuleVerification.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(builtInRuleVerification.ThingPreference); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing BuiltInRuleVerification for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(builtInRuleVerification.Actor.HasValue) - { - writer.WriteStringValue(builtInRuleVerification.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(builtInRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in builtInRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in builtInRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(builtInRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(builtInRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(builtInRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(builtInRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(builtInRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(builtInRuleVerification.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(builtInRuleVerification.RevisionNumber); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(builtInRuleVerification.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(builtInRuleVerification.ThingPreference); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in builtInRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "executedOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isActive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "violation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs index 65054c330..92545d84e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CategorySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,516 +51,231 @@ namespace CDP4JsonSerializer public class CategorySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not Category category) + { + throw new ArgumentException("The thing shall be a Category", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of Category since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Category for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var permissibleClassItem in category.PermissibleClass) { - return; + writer.WriteStringValue(permissibleClassItem.ToString()); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); + + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(superCategoryItem); } + writer.WriteEndArray(); + break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Category for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(category.Iid); + writer.WritePropertyName("isAbstract"u8); + writer.WriteBooleanValue(category.IsAbstract); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(category.Name); + writer.WriteStartArray("permissibleClass"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var permissibleClassItem in category.PermissibleClass) { - return; + writer.WriteStringValue(permissibleClassItem.ToString()); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(category.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(category.ShortName); + writer.WriteStartArray("superCategory"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(superCategoryItem); } - + writer.WriteEndArray(); + break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Category for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isabstract": - var allowedVersionsForIsAbstract = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(category.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForIsAbstract.Contains(requestedVersion)) + foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("isAbstract"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "permissibleclass": - var allowedVersionsForPermissibleClass = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPermissibleClass.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("permissibleClass"u8); - - if(value is IEnumerable objectListPermissibleClass) - { - foreach(var permissibleClassItem in objectListPermissibleClass) - { - writer.WriteStringValue(((ClassKind)permissibleClassItem).ToString()); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "supercategory": - var allowedVersionsForSuperCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSuperCategory.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("superCategory"u8); - - if(value is IEnumerable objectListSuperCategory) - { - foreach(var superCategoryItem in objectListSuperCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(superCategoryItem); - } - } - writer.WriteEndArray(); - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Category"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Category category) - { - throw new ArgumentException("The thing shall be a Category", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Category since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(category.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); writer.WritePropertyName("iid"u8); writer.WriteStringValue(category.Iid); writer.WritePropertyName("isAbstract"u8); writer.WriteBooleanValue(category.IsAbstract); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(category.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(category.Name); writer.WriteStartArray("permissibleClass"u8); @@ -570,6 +286,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(category.RevisionNumber); writer.WritePropertyName("shortName"u8); @@ -582,9 +299,23 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(category.ThingPreference); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Category for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(category.Actor.HasValue) + { + writer.WriteStringValue(category.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) @@ -593,6 +324,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(category.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -603,6 +335,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -611,6 +344,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -619,6 +353,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -627,6 +362,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(category.Iid); writer.WritePropertyName("isAbstract"u8); @@ -645,6 +381,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(category.RevisionNumber); writer.WritePropertyName("shortName"u8); @@ -657,178 +394,365 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(category.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.2.0"); - writer.WriteStartArray("alias"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(category.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("actor"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(category.Iid); - writer.WritePropertyName("isAbstract"u8); - writer.WriteBooleanValue(category.IsAbstract); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(category.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(category.Name); - writer.WriteStartArray("permissibleClass"u8); + writer.WriteStartArray("alias"u8); - foreach(var permissibleClassItem in category.PermissibleClass) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(permissibleClassItem.ToString()); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(category.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(category.ShortName); - writer.WriteStartArray("superCategory"u8); - - foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { - writer.WriteStringValue(superCategoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(category.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Category for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(category.Actor.HasValue) + writer.WritePropertyName("classKind"u8); + + if(value != null) { - writer.WriteStringValue(category.Actor.Value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in category.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(category.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - foreach(var definitionItem in category.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in category.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in category.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in category.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(category.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isabstract": + if(!AllowedVersionsPerProperty["isAbstract"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("isAbstract"u8); - writer.WriteBooleanValue(category.IsAbstract); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(category.IsDeprecated); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(category.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("name"u8); - writer.WriteStringValue(category.Name); - writer.WriteStartArray("permissibleClass"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var permissibleClassItem in category.PermissibleClass) + break; + case "permissibleclass": + if(!AllowedVersionsPerProperty["permissibleClass"].Contains(requestedVersion)) { - writer.WriteStringValue(permissibleClassItem.ToString()); + return; } + writer.WriteStartArray("permissibleClass"u8); + + if(value is IEnumerable objectListPermissibleClass) + { + foreach(var permissibleClassItem in objectListPermissibleClass) + { + writer.WriteStringValue(((ClassKind)permissibleClassItem).ToString()); + } + } + writer.WriteEndArray(); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(category.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(category.ShortName); - writer.WriteStartArray("superCategory"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var superCategoryItem in category.SuperCategory.OrderBy(x => x, this.GuidComparer)) + break; + case "supercategory": + if(!AllowedVersionsPerProperty["superCategory"].Contains(requestedVersion)) { - writer.WriteStringValue(superCategoryItem); + return; } + writer.WriteStartArray("superCategory"u8); + + if(value is IEnumerable objectListSuperCategory) + { + foreach(var superCategoryItem in objectListSuperCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(superCategoryItem); + } + } + writer.WriteEndArray(); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(category.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Category"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isAbstract", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "permissibleClass", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "superCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs index eaa2878c0..f51c63661 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeProposalSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,330 +51,460 @@ namespace CDP4JsonSerializer public class ChangeProposalSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ChangeProposal changeProposal) + { + throw new ArgumentException("The thing shall be a ChangeProposal", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ChangeProposal since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeProposal for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeProposal.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); break; - case "changerequest": - var allowedVersionsForChangeRequest = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeProposal for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForChangeRequest.Contains(requestedVersion)) + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("changeRequest"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeProposal.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeProposal.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeProposal for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(changeProposal.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(changeProposal.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeProposal.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("changeRequest"u8); + writer.WriteStringValue(changeProposal.ChangeRequest); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeProposal.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeProposal.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeProposal.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(discussionItem); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("discussion"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeProposal.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeProposal.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeProposal.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(value is IEnumerable objectListDiscussion) + if(changeProposal.PrimaryAnnotatedThing.HasValue) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeProposal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeProposal.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeProposal.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeProposal.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeProposal.Title); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + break; + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("approvedBy"u8); - if(value is IEnumerable objectListExcludedDomain) + if(value is IEnumerable objectListApprovedBy) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(approvedByItem); } } writer.WriteEndArray(); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedPerson) + if(value is IEnumerable objectListCategory) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + case "changerequest": + if(!AllowedVersionsPerProperty["changeRequest"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("changeRequest"u8); if(value != null) { @@ -385,24 +516,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -410,24 +534,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,24 +552,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -460,24 +570,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -485,49 +588,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("relatedThing"u8); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListRelatedThing) + if(value is IEnumerable objectListExcludedDomain) { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(relatedThingItem); + writer.WriteStringValue(excludedDomainItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -535,20 +660,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -560,49 +678,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); - - if(value is IEnumerable objectListSourceAnnotation) - { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - } - - writer.WriteEndArray(); - break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("status"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -610,23 +696,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("owner"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -634,24 +714,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("primaryAnnotatedThing"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -659,351 +732,167 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeProposal"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ChangeProposal changeProposal) - { - throw new ArgumentException("The thing shall be a ChangeProposal", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ChangeProposal since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeProposal.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeRequest"u8); - writer.WriteStringValue(changeProposal.ChangeRequest); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeProposal.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeProposal.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeProposal.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(excludedDomainItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeProposal.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeProposal.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeProposal.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeProposal.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeProposal.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeProposal.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeProposal.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeProposal.Title); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(approvedByItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeProposal.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("changeRequest"u8); - writer.WriteStringValue(changeProposal.ChangeRequest); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeProposal.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeProposal.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeProposal.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("sourceAnnotation"u8); - foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(excludedDomainItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeProposal.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeProposal.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeProposal.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeProposal.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeProposal.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeProposal.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(sourceAnnotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeProposal.Status.ToString()); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(changeProposal.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeProposal.Title); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeProposal for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(changeProposal.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(changeProposal.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeProposal.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeProposal.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeProposal.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeRequest"u8); - writer.WriteStringValue(changeProposal.ChangeRequest); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeProposal.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeProposal.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeProposal.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeProposal.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeProposal.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in changeProposal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeProposal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeProposal.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeProposal.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeProposal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeProposal.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeProposal.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(changeProposal.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeProposal.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeProposal.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeProposal.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in changeProposal.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeProposal.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(changeProposal.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeProposal.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeProposal"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "changeRequest", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs index 2a227e46e..a7b2b58e5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ChangeRequestSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,305 +51,382 @@ namespace CDP4JsonSerializer public class ChangeRequestSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ChangeRequest changeRequest) + { + throw new ArgumentException("The thing shall be a ChangeRequest", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ChangeRequest since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeRequest for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeRequest.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeRequest for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(changeRequest.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeRequest.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ChangeRequest for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(changeRequest.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(changeRequest.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WriteStartArray("discussion"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(changeRequest.Author); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDiscussion) + foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(changeRequest.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(changeRequest.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(changeRequest.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(changeRequest.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(changeRequest.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(changeRequest.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(changeRequest.PrimaryAnnotatedThing.HasValue) { - return; + writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("relatedThing"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(relatedThingItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(changeRequest.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(changeRequest.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(changeRequest.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(changeRequest.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(changeRequest.Title); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -360,24 +438,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("author"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -385,24 +474,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -410,24 +510,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,24 +528,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -460,49 +546,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("relatedThing"u8); - - if(value is IEnumerable objectListRelatedThing) - { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -510,74 +564,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) { - writer.WriteStringValue((string)value); + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListSourceAnnotation) + if(value is IEnumerable objectListExcludedPerson) { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(sourceAnnotationItem); + writer.WriteStringValue(excludedPersonItem); } } writer.WriteEndArray(); break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("status"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -585,19 +636,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -609,24 +654,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -634,345 +672,202 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeRequest"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ChangeRequest changeRequest) - { - throw new ArgumentException("The thing shall be a ChangeRequest", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ChangeRequest since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeRequest.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeRequest.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeRequest.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeRequest.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeRequest.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeRequest.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeRequest.Owner); writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeRequest.PrimaryAnnotatedThing.HasValue) + + if(value != null) { - writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeRequest.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeRequest.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeRequest.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeRequest.Title); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeRequest.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeRequest.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeRequest.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeRequest.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeRequest.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeRequest.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeRequest.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeRequest.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeRequest.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeRequest.ShortName); writer.WriteStartArray("sourceAnnotation"u8); - foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeRequest.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(changeRequest.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeRequest.Title); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ChangeRequest for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) + { + return; + } - if(changeRequest.Actor.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(changeRequest.Actor.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in changeRequest.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(changeRequest.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in changeRequest.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(changeRequest.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(changeRequest.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(changeRequest.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(changeRequest.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in changeRequest.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in changeRequest.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in changeRequest.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(changeRequest.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(changeRequest.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(changeRequest.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(changeRequest.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(changeRequest.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(changeRequest.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in changeRequest.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(changeRequest.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(changeRequest.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in changeRequest.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(changeRequest.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(changeRequest.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(changeRequest.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ChangeRequest"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs index 51f47dc83..423ff51c3 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CitationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,189 @@ namespace CDP4JsonSerializer /// public class CitationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Citation citation) + { + throw new ArgumentException("The thing shall be a Citation", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Citation since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Citation for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Citation for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Citation for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(citation.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Citation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(citation.Actor.HasValue) + { + writer.WriteStringValue(citation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(citation.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(citation.Iid); + writer.WritePropertyName("isAdaptation"u8); + writer.WriteBooleanValue(citation.IsAdaptation); + writer.WritePropertyName("location"u8); + writer.WriteStringValue(citation.Location); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("remark"u8); + writer.WriteStringValue(citation.Remark); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(citation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(citation.ShortName); + writer.WritePropertyName("source"u8); + writer.WriteStringValue(citation.Source); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(citation.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +240,7 @@ public class CitationSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +248,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +266,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +284,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +302,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +320,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,15 +338,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isadaptation": - var allowedVersionsForIsAdaptation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsAdaptation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isAdaptation"].Contains(requestedVersion)) { return; } @@ -214,15 +356,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "location": - var allowedVersionsForLocation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLocation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["location"].Contains(requestedVersion)) { return; } @@ -240,14 +374,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +392,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "remark": - var allowedVersionsForRemark = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRemark.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["remark"].Contains(requestedVersion)) { return; } @@ -291,15 +410,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,15 +428,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -343,15 +446,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "source": - var allowedVersionsForSource = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSource.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["source"].Contains(requestedVersion)) { return; } @@ -369,13 +464,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -398,181 +487,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Citation citation) - { - throw new ArgumentException("The thing shall be a Citation", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Citation since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(citation.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(citation.Iid); - writer.WritePropertyName("isAdaptation"u8); - writer.WriteBooleanValue(citation.IsAdaptation); - writer.WritePropertyName("location"u8); - writer.WriteStringValue(citation.Location); - writer.WritePropertyName("remark"u8); - writer.WriteStringValue(citation.Remark); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(citation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(citation.ShortName); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(citation.Source); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(citation.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(citation.Iid); - writer.WritePropertyName("isAdaptation"u8); - writer.WriteBooleanValue(citation.IsAdaptation); - writer.WritePropertyName("location"u8); - writer.WriteStringValue(citation.Location); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("remark"u8); - writer.WriteStringValue(citation.Remark); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(citation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(citation.ShortName); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(citation.Source); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(citation.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(citation.Iid); - writer.WritePropertyName("isAdaptation"u8); - writer.WriteBooleanValue(citation.IsAdaptation); - writer.WritePropertyName("location"u8); - writer.WriteStringValue(citation.Location); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("remark"u8); - writer.WriteStringValue(citation.Remark); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(citation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(citation.ShortName); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(citation.Source); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(citation.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Citation for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(citation.Actor.HasValue) - { - writer.WriteStringValue(citation.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(citation.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in citation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in citation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(citation.Iid); - writer.WritePropertyName("isAdaptation"u8); - writer.WriteBooleanValue(citation.IsAdaptation); - writer.WritePropertyName("location"u8); - writer.WriteStringValue(citation.Location); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(citation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("remark"u8); - writer.WriteStringValue(citation.Remark); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(citation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(citation.ShortName); - writer.WritePropertyName("source"u8); - writer.WriteStringValue(citation.Source); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(citation.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isAdaptation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "location", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "remark", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "source", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs index 6d9c521f6..24f898ef3 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ColorSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,181 @@ namespace CDP4JsonSerializer /// public class ColorSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Color color) + { + throw new ArgumentException("The thing shall be a Color", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Color since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Color for Version 1.0.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Color for Version 1.1.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Color for Version 1.2.0"); + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(color.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Color for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(color.Actor.HasValue) + { + writer.WriteStringValue(color.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("blue"u8); + writer.WriteNumberValue(color.Blue); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(color.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("green"u8); + writer.WriteNumberValue(color.Green); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(color.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(color.Name); + writer.WritePropertyName("red"u8); + writer.WriteNumberValue(color.Red); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(color.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(color.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +232,7 @@ public class ColorSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +240,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +258,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "blue": - var allowedVersionsForBlue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForBlue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["blue"].Contains(requestedVersion)) { return; } @@ -112,15 +276,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -138,14 +294,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +312,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +330,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "green": - var allowedVersionsForGreen = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForGreen.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["green"].Contains(requestedVersion)) { return; } @@ -214,15 +348,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -240,14 +366,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +384,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -291,15 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "red": - var allowedVersionsForRed = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRed.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["red"].Contains(requestedVersion)) { return; } @@ -317,15 +420,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -343,13 +438,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -372,173 +461,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Color color) - { - throw new ArgumentException("The thing shall be a Color", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Color since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.0.0"); - writer.WritePropertyName("blue"u8); - writer.WriteNumberValue(color.Blue); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(color.ClassKind.ToString()); - writer.WritePropertyName("green"u8); - writer.WriteNumberValue(color.Green); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(color.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(color.Name); - writer.WritePropertyName("red"u8); - writer.WriteNumberValue(color.Red); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(color.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.1.0"); - writer.WritePropertyName("blue"u8); - writer.WriteNumberValue(color.Blue); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(color.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("green"u8); - writer.WriteNumberValue(color.Green); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(color.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(color.Name); - writer.WritePropertyName("red"u8); - writer.WriteNumberValue(color.Red); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(color.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.2.0"); - writer.WritePropertyName("blue"u8); - writer.WriteNumberValue(color.Blue); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(color.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("green"u8); - writer.WriteNumberValue(color.Green); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(color.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(color.Name); - writer.WritePropertyName("red"u8); - writer.WriteNumberValue(color.Red); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(color.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(color.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Color for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(color.Actor.HasValue) - { - writer.WriteStringValue(color.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("blue"u8); - writer.WriteNumberValue(color.Blue); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(color.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in color.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in color.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("green"u8); - writer.WriteNumberValue(color.Green); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(color.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(color.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(color.Name); - writer.WritePropertyName("red"u8); - writer.WriteNumberValue(color.Red); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(color.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(color.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "blue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "green", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "red", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs index a5f4403a5..f246db2b5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CommonFileStoreSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,245 @@ namespace CDP4JsonSerializer /// public class CommonFileStoreSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not CommonFileStore commonFileStore) + { + throw new ArgumentException("The thing shall be a CommonFileStore", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of CommonFileStore since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing CommonFileStore for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing CommonFileStore for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing CommonFileStore for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(commonFileStore.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing CommonFileStore for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(commonFileStore.Actor.HasValue) + { + writer.WriteStringValue(commonFileStore.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(commonFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(commonFileStore.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(commonFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(commonFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(commonFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(commonFileStore.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +296,7 @@ public class CommonFileStoreSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -138,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "file": - var allowedVersionsForFile = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFile.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["file"].Contains(requestedVersion)) { return; } @@ -214,15 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "folder": - var allowedVersionsForFolder = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFolder.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["folder"].Contains(requestedVersion)) { return; } @@ -240,15 +430,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -266,14 +448,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -291,15 +466,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -317,15 +484,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -343,15 +502,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -369,13 +520,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -398,229 +543,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not CommonFileStore commonFileStore) - { - throw new ArgumentException("The thing shall be a CommonFileStore", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of CommonFileStore since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(commonFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(commonFileStore.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(commonFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(commonFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(commonFileStore.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(commonFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(commonFileStore.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(commonFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(commonFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(commonFileStore.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(commonFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(commonFileStore.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(commonFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(commonFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(commonFileStore.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(commonFileStore.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing CommonFileStore for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(commonFileStore.Actor.HasValue) - { - writer.WriteStringValue(commonFileStore.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(commonFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(commonFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in commonFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in commonFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in commonFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in commonFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(commonFileStore.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(commonFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(commonFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(commonFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(commonFileStore.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(commonFileStore.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "file", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "folder", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs index 7ab792415..09cc7998b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CompoundParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,393 @@ namespace CDP4JsonSerializer public class CompoundParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not CompoundParameterType compoundParameterType) + { + throw new ArgumentException("The thing shall be a CompoundParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of CompoundParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing CompoundParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(componentItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing CompoundParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(componentItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "component": - var allowedVersionsForComponent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForComponent.Contains(requestedVersion)) + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("component"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListComponent) + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(componentItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing CompoundParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(componentItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(compoundParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing CompoundParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(compoundParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(compoundParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); + writer.WriteStartArray("component"u8); + + foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(componentItem); } - break; - case "isfinalized": - var allowedVersionsForIsFinalized = new List + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIsFinalized.Contains(requestedVersion)) + foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("isFinalized"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(compoundParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(compoundParameterType.IsDeprecated); + writer.WritePropertyName("isFinalized"u8); + writer.WriteBooleanValue(compoundParameterType.IsFinalized); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(compoundParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(compoundParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(compoundParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(compoundParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(compoundParameterType.ThingPreference); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +445,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,51 +499,107 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List + case "component": + if(!AllowedVersionsPerProperty["component"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("component"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(value is IEnumerable objectListComponent) + { + foreach(var componentItem in objectListComponent.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(componentItem); + } + } + + writer.WriteEndArray(); + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } - if(value != null) + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue((string)value); + return; } - else + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteNullValue(); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; } + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); break; - case "symbol": - var allowedVersionsForSymbol = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -498,23 +607,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -522,347 +625,161 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the CompoundParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not CompoundParameterType compoundParameterType) - { - throw new ArgumentException("The thing shall be a CompoundParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of CompoundParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(componentItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + case "isfinalized": + if(!AllowedVersionsPerProperty["isFinalized"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(compoundParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(compoundParameterType.IsDeprecated); writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(compoundParameterType.IsFinalized); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(compoundParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(compoundParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(compoundParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(compoundParameterType.Symbol); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(componentItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(compoundParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(compoundParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(compoundParameterType.IsFinalized); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(compoundParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(compoundParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(compoundParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(compoundParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(componentItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(compoundParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(compoundParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(compoundParameterType.IsFinalized); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(compoundParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(compoundParameterType.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(compoundParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(compoundParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(compoundParameterType.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing CompoundParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(compoundParameterType.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(compoundParameterType.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in compoundParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in compoundParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(compoundParameterType.ClassKind.ToString()); - writer.WriteStartArray("component"u8); - - foreach(var componentItem in compoundParameterType.Component.OrderBy(x => x, this.OrderedItemComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteOrderedItem(componentItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in compoundParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in compoundParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in compoundParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in compoundParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(compoundParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(compoundParameterType.IsDeprecated); - writer.WritePropertyName("isFinalized"u8); - writer.WriteBooleanValue(compoundParameterType.IsFinalized); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(compoundParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(compoundParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(compoundParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(compoundParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(compoundParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(compoundParameterType.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the CompoundParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "component", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isFinalized", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs index 6e2f969cc..412e656be 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ConstantSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,391 +51,393 @@ namespace CDP4JsonSerializer public class ConstantSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not Constant constant) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a Constant", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Constant since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Constant for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListCategory) + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(constant.Scale.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Constant for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDefinition) + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(constant.Scale.HasValue) { - return; + writer.WriteStringValue(constant.Scale.Value); } - - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) + else { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteNullValue(); } - - writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Constant for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(constant.Scale.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(constant.ThingPreference); + writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("name"u8); - - if(value != null) + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Constant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(constant.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(constant.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "parametertype": - var allowedVersionsForParameterType = new List + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("parameterType"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(constant.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(constant.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(constant.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(constant.Name); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(constant.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(constant.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(constant.Scale.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(constant.Scale.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(constant.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(constant.ThingPreference); + writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForScale.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("scale"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -446,49 +449,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -496,371 +503,277 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Constant"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Constant constant) - { - throw new ArgumentException("The thing shall be a Constant", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Constant since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("definition"u8); - foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(aliasItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(constant.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(definitionItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(constant.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(constant.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(constant.Name); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(constant.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(constant.RevisionNumber); - writer.WritePropertyName("scale"u8); + writer.WriteStartArray("excludedPerson"u8); - if(constant.Scale.HasValue) - { - writer.WriteStringValue(constant.Scale.Value); - } - else + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteNullValue(); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(constant.ShortName); - writer.WriteString("value"u8, constant.Value.ToJsonString()); + + writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(categoryItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(constant.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(constant.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(constant.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(constant.Name); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(constant.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(constant.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(constant.Scale.HasValue) + + if(value != null) { - writer.WriteStringValue(constant.Scale.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(constant.ShortName); - writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(constant.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "parametertype": + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(constant.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(constant.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(constant.Name); writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(constant.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(constant.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(constant.Scale.HasValue) + + if(value != null) { - writer.WriteStringValue(constant.Scale.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(constant.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(constant.ThingPreference); - writer.WriteString("value"u8, constant.Value.ToJsonString()); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Constant for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(constant.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(constant.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in constant.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "scale": + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in constant.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("scale"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(constant.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in constant.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in constant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in constant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in constant.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(constant.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(constant.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(constant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(constant.Name); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(constant.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(constant.RevisionNumber); - writer.WritePropertyName("scale"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(constant.Scale.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(constant.Scale.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(constant.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(constant.ThingPreference); - writer.WriteString("value"u8, constant.Value.ToJsonString()); + break; + case "value": + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("value"u8, ((ValueArray)value).ToJsonString()); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Constant"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs index 494f45e35..8d6aaf3db 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ContractChangeNoticeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,330 +51,460 @@ namespace CDP4JsonSerializer public class ContractChangeNoticeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ContractChangeNotice contractChangeNotice) + { + throw new ArgumentException("The thing shall be a ContractChangeNotice", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ContractChangeNotice since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ContractChangeNotice for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); break; - case "changeproposal": - var allowedVersionsForChangeProposal = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ContractChangeNotice for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForChangeProposal.Contains(requestedVersion)) + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("changeProposal"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(contractChangeNotice.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ContractChangeNotice for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(contractChangeNotice.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(contractChangeNotice.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + writer.WriteStringValue(contractChangeNotice.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("changeProposal"u8); + writer.WriteStringValue(contractChangeNotice.ChangeProposal); + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(contractChangeNotice.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(contractChangeNotice.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(discussionItem); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("discussion"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(contractChangeNotice.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(contractChangeNotice.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(contractChangeNotice.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(value is IEnumerable objectListDiscussion) + if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(contractChangeNotice.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(contractChangeNotice.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(contractChangeNotice.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(contractChangeNotice.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(contractChangeNotice.Title); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + break; + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("approvedBy"u8); - if(value is IEnumerable objectListExcludedDomain) + if(value is IEnumerable objectListApprovedBy) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(approvedByItem); } } writer.WriteEndArray(); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedPerson) + if(value is IEnumerable objectListCategory) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + case "changeproposal": + if(!AllowedVersionsPerProperty["changeProposal"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("changeProposal"u8); if(value != null) { @@ -385,24 +516,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -410,24 +534,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,24 +552,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -460,24 +570,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -485,49 +588,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("relatedThing"u8); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListRelatedThing) + if(value is IEnumerable objectListExcludedDomain) { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(relatedThingItem); + writer.WriteStringValue(excludedDomainItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -535,20 +660,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -560,49 +678,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); - - if(value is IEnumerable objectListSourceAnnotation) - { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - } - - writer.WriteEndArray(); - break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("status"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -610,23 +696,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("owner"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -634,24 +714,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("primaryAnnotatedThing"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -659,351 +732,167 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ContractChangeNotice"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ContractChangeNotice contractChangeNotice) - { - throw new ArgumentException("The thing shall be a ContractChangeNotice", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ContractChangeNotice since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(contractChangeNotice.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeProposal"u8); - writer.WriteStringValue(contractChangeNotice.ChangeProposal); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(contractChangeNotice.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(contractChangeNotice.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(excludedDomainItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(contractChangeNotice.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(contractChangeNotice.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(contractChangeNotice.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(contractChangeNotice.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(contractChangeNotice.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(contractChangeNotice.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(contractChangeNotice.Title); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(approvedByItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(contractChangeNotice.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("changeProposal"u8); - writer.WriteStringValue(contractChangeNotice.ChangeProposal); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(contractChangeNotice.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(contractChangeNotice.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("sourceAnnotation"u8); - foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(excludedDomainItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(contractChangeNotice.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(contractChangeNotice.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(contractChangeNotice.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(contractChangeNotice.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(contractChangeNotice.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(sourceAnnotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(contractChangeNotice.Status.ToString()); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(contractChangeNotice.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(contractChangeNotice.Title); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ContractChangeNotice for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(contractChangeNotice.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(contractChangeNotice.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in contractChangeNotice.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(contractChangeNotice.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in contractChangeNotice.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeProposal"u8); - writer.WriteStringValue(contractChangeNotice.ChangeProposal); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(contractChangeNotice.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(contractChangeNotice.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(contractChangeNotice.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(contractChangeNotice.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in contractChangeNotice.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in contractChangeNotice.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in contractChangeNotice.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(contractChangeNotice.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(contractChangeNotice.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(contractChangeNotice.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(contractChangeNotice.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(contractChangeNotice.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(contractChangeNotice.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in contractChangeNotice.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(contractChangeNotice.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(contractChangeNotice.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in contractChangeNotice.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(contractChangeNotice.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(contractChangeNotice.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(contractChangeNotice.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ContractChangeNotice"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "changeProposal", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs index 74aba1f5b..e8a0f05f7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/CyclicRatioScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,370 +51,449 @@ namespace CDP4JsonSerializer public class CyclicRatioScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not CyclicRatioScale cyclicRatioScale) + { + throw new ArgumentException("The thing shall be a CyclicRatioScale", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of CyclicRatioScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing CyclicRatioScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListAlias) + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing CyclicRatioScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing CyclicRatioScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(mappingToReferenceScaleItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(cyclicRatioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing CyclicRatioScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(cyclicRatioScale.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(cyclicRatioScale.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "ismaximuminclusive": - var allowedVersionsForIsMaximumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "isminimuminclusive": - var allowedVersionsForIsMinimumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "mappingtoreferencescale": - var allowedVersionsForMappingToReferenceScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(cyclicRatioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListMappingToReferenceScale) + foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } + writer.WriteStringValue(mappingToReferenceScaleItem); } - + writer.WriteEndArray(); - break; - case "maximumpermissiblevalue": - var allowedVersionsForMaximumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("modulus"u8); + writer.WriteStringValue(cyclicRatioScale.Modulus); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(cyclicRatioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(cyclicRatioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(cyclicRatioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(cyclicRatioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - break; - case "minimumpermissiblevalue": - var allowedVersionsForMinimumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -421,50 +501,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "modulus": - var allowedVersionsForModulus = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModulus.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modulus"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,48 +537,176 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - case "negativevalueconnotation": - var allowedVersionsForNegativeValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("negativeValueConnotation"u8); - + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + if(!AllowedVersionsPerProperty["isMaximumInclusive"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + if(!AllowedVersionsPerProperty["isMinimumInclusive"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + if(!AllowedVersionsPerProperty["mappingToReferenceScale"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + if(!AllowedVersionsPerProperty["maximumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); + if(value != null) { writer.WriteStringValue((string)value); @@ -524,16 +717,98 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "numberset": - var allowedVersionsForNumberSet = new List + case "minimumpermissiblevalue": + if(!AllowedVersionsPerProperty["minimumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modulus": + if(!AllowedVersionsPerProperty["modulus"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modulus"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + if(!AllowedVersionsPerProperty["negativeValueConnotation"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + break; + case "numberset": + if(!AllowedVersionsPerProperty["numberSet"].Contains(requestedVersion)) { return; } @@ -551,15 +826,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "positivevalueconnotation": - var allowedVersionsForPositiveValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["positiveValueConnotation"].Contains(requestedVersion)) { return; } @@ -577,15 +844,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -603,15 +862,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -629,13 +880,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -653,15 +898,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { return; } @@ -679,15 +916,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valuedefinition": - var allowedVersionsForValueDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { return; } @@ -710,397 +939,36 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not CyclicRatioScale cyclicRatioScale) - { - throw new ArgumentException("The thing shall be a CyclicRatioScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of CyclicRatioScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(cyclicRatioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); - writer.WritePropertyName("modulus"u8); - writer.WriteStringValue(cyclicRatioScale.Modulus); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(cyclicRatioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(cyclicRatioScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(cyclicRatioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(cyclicRatioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("modulus"u8); - writer.WriteStringValue(cyclicRatioScale.Modulus); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(cyclicRatioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(cyclicRatioScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(cyclicRatioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(cyclicRatioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("modulus"u8); - writer.WriteStringValue(cyclicRatioScale.Modulus); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(cyclicRatioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(cyclicRatioScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(cyclicRatioScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(cyclicRatioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing CyclicRatioScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(cyclicRatioScale.Actor.HasValue) - { - writer.WriteStringValue(cyclicRatioScale.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in cyclicRatioScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(cyclicRatioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in cyclicRatioScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in cyclicRatioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in cyclicRatioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in cyclicRatioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(cyclicRatioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(cyclicRatioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in cyclicRatioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(cyclicRatioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(cyclicRatioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("modulus"u8); - writer.WriteStringValue(cyclicRatioScale.Modulus); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(cyclicRatioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(cyclicRatioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(cyclicRatioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(cyclicRatioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(cyclicRatioScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(cyclicRatioScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(cyclicRatioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in cyclicRatioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMaximumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMinimumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "mappingToReferenceScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maximumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minimumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modulus", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "negativeValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "numberSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "positiveValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs index 9835c3d53..9e479ed0c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DateParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,349 @@ namespace CDP4JsonSerializer public class DateParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DateParameterType dateParameterType) + { + throw new ArgumentException("The thing shall be a DateParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DateParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DateParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DateParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DateParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DateParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(dateParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(dateParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateParameterType.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DateParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DateParameterType dateParameterType) - { - throw new ArgumentException("The thing shall be a DateParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DateParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dateParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DateParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(dateParameterType.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(dateParameterType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dateParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DateParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs index 403c97965..c75c8db26 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DateTimeParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,349 @@ namespace CDP4JsonSerializer public class DateTimeParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DateTimeParameterType dateTimeParameterType) + { + throw new ArgumentException("The thing shall be a DateTimeParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DateTimeParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DateTimeParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DateTimeParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DateTimeParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateTimeParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DateTimeParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(dateTimeParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(dateTimeParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dateTimeParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(dateTimeParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(dateTimeParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(dateTimeParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dateTimeParameterType.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DateTimeParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DateTimeParameterType dateTimeParameterType) - { - throw new ArgumentException("The thing shall be a DateTimeParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DateTimeParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateTimeParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateTimeParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateTimeParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateTimeParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateTimeParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateTimeParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateTimeParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateTimeParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateTimeParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateTimeParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateTimeParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateTimeParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dateTimeParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DateTimeParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(dateTimeParameterType.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(dateTimeParameterType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in dateTimeParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in dateTimeParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dateTimeParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in dateTimeParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dateTimeParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dateTimeParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in dateTimeParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dateTimeParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(dateTimeParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dateTimeParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(dateTimeParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dateTimeParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(dateTimeParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(dateTimeParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dateTimeParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DateTimeParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs index 9f49314eb..1bcb6fc13 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DecompositionRuleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,369 +51,401 @@ namespace CDP4JsonSerializer public class DecompositionRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DecompositionRule decompositionRule) + { + throw new ArgumentException("The thing shall be a DecompositionRule", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DecompositionRule since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DecompositionRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(containedCategoryItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListAlias) + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteNumberValue(decompositionRule.MaxContained.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); break; - case "containedcategory": - var allowedVersionsForContainedCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DecompositionRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForContainedCategory.Contains(requestedVersion)) + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); writer.WriteStartArray("containedCategory"u8); - if(value is IEnumerable objectListContainedCategory) + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var containedCategoryItem in objectListContainedCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(containedCategoryItem); - } + writer.WriteStringValue(containedCategoryItem); } - + writer.WriteEndArray(); - break; - case "containingcategory": - var allowedVersionsForContainingCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForContainingCategory.Contains(requestedVersion)) + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("containingCategory"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(decompositionRule.MaxContained.HasValue) { - return; + writer.WriteNumberValue(decompositionRule.MaxContained.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedDomain"u8); + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DecompositionRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(containedCategoryItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteNumberValue(decompositionRule.MaxContained.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(decompositionRule.ThingPreference); break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DecompositionRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(decompositionRule.Actor.HasValue) { - return; + writer.WriteStringValue(decompositionRule.Actor.Value); + } + else + { + writer.WriteNullValue(); } - writer.WritePropertyName("isDeprecated"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(aliasItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(decompositionRule.ClassKind.ToString()); + writer.WriteStartArray("containedCategory"u8); + + foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(containedCategoryItem); } - break; - case "maxcontained": - var allowedVersionsForMaxContained = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("containingCategory"u8); + writer.WriteStringValue(decompositionRule.ContainingCategory); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForMaxContained.Contains(requestedVersion)) + foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("maxContained"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "mincontained": - var allowedVersionsForMinContained = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForMinContained.Contains(requestedVersion)) + foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("minContained"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(decompositionRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(decompositionRule.IsDeprecated); + writer.WritePropertyName("maxContained"u8); + + if(decompositionRule.MaxContained.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteNumberValue(decompositionRule.MaxContained.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("minContained"u8); + writer.WriteNumberValue(decompositionRule.MinContained); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(decompositionRule.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(decompositionRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(decompositionRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(decompositionRule.ThingPreference); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { @@ -420,51 +453,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,49 +489,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "containedcategory": + if(!AllowedVersionsPerProperty["containedCategory"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("containedCategory"u8); + + if(value is IEnumerable objectListContainedCategory) { - writer.WriteNullValue(); + foreach(var containedCategoryItem in objectListContainedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedCategoryItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "containingcategory": + if(!AllowedVersionsPerProperty["containingCategory"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("containingCategory"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -522,359 +525,269 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DecompositionRule"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DecompositionRule decompositionRule) - { - throw new ArgumentException("The thing shall be a DecompositionRule", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DecompositionRule since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(decompositionRule.ClassKind.ToString()); - writer.WriteStartArray("containedCategory"u8); + writer.WriteStartArray("definition"u8); - foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(containedCategoryItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("containingCategory"u8); - writer.WriteStringValue(decompositionRule.ContainingCategory); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(hyperLinkItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(decompositionRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(decompositionRule.IsDeprecated); - writer.WritePropertyName("maxContained"u8); - - if(decompositionRule.MaxContained.HasValue) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNumberValue(decompositionRule.MaxContained.Value); + return; } - else + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteNullValue(); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - - writer.WritePropertyName("minContained"u8); - writer.WriteNumberValue(decompositionRule.MinContained); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(decompositionRule.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(decompositionRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(decompositionRule.ShortName); + + writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(decompositionRule.ClassKind.ToString()); - writer.WriteStartArray("containedCategory"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(containedCategoryItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("containingCategory"u8); - writer.WriteStringValue(decompositionRule.ContainingCategory); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(decompositionRule.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(decompositionRule.IsDeprecated); - writer.WritePropertyName("maxContained"u8); - - if(decompositionRule.MaxContained.HasValue) + + if(value != null) { - writer.WriteNumberValue(decompositionRule.MaxContained.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("minContained"u8); - writer.WriteNumberValue(decompositionRule.MinContained); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(decompositionRule.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(decompositionRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(decompositionRule.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "maxcontained": + if(!AllowedVersionsPerProperty["maxContained"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(decompositionRule.ClassKind.ToString()); - writer.WriteStartArray("containedCategory"u8); - - foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("maxContained"u8); + + if(value != null) { - writer.WriteStringValue(containedCategoryItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("containingCategory"u8); - writer.WriteStringValue(decompositionRule.ContainingCategory); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "mincontained": + if(!AllowedVersionsPerProperty["minContained"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("minContained"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(decompositionRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(decompositionRule.IsDeprecated); - writer.WritePropertyName("maxContained"u8); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(decompositionRule.MaxContained.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteNumberValue(decompositionRule.MaxContained.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("minContained"u8); - writer.WriteNumberValue(decompositionRule.MinContained); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(decompositionRule.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(decompositionRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(decompositionRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(decompositionRule.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DecompositionRule for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } - if(decompositionRule.Actor.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(decompositionRule.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in decompositionRule.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(decompositionRule.ClassKind.ToString()); - writer.WriteStartArray("containedCategory"u8); - - foreach(var containedCategoryItem in decompositionRule.ContainedCategory.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(containedCategoryItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("containingCategory"u8); - writer.WriteStringValue(decompositionRule.ContainingCategory); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in decompositionRule.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in decompositionRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in decompositionRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in decompositionRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(decompositionRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(decompositionRule.IsDeprecated); - writer.WritePropertyName("maxContained"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(decompositionRule.MaxContained.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteNumberValue(decompositionRule.MaxContained.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("minContained"u8); - writer.WriteNumberValue(decompositionRule.MinContained); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(decompositionRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(decompositionRule.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(decompositionRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(decompositionRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(decompositionRule.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DecompositionRule"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containedCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containingCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maxContained", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minContained", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs index dd3899aae..8554d8d6e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DefinitionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,354 +50,6 @@ namespace CDP4JsonSerializer /// public class DefinitionSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "citation": - var allowedVersionsForCitation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCitation.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("citation"u8); - - if(value is IEnumerable objectListCitation) - { - foreach(var citationItem in objectListCitation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(citationItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "content": - var allowedVersionsForContent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("content"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "example": - var allowedVersionsForExample = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExample.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("example"u8); - - if(value is IEnumerable objectListExample) - { - foreach(var exampleItem in objectListExample.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(exampleItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("languageCode"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "note": - var allowedVersionsForNote = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNote.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("note"u8); - - if(value is IEnumerable objectListNote) - { - foreach(var noteItem in objectListNote.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(noteItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Definition"); - } - } - /// /// Serializes a into an /// @@ -423,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing Definition for Version 1.0.0"); writer.WriteStartArray("citation"u8); foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) @@ -432,6 +85,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(definition.ClassKind.ToString()); writer.WritePropertyName("content"u8); @@ -444,6 +98,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(definition.Iid); writer.WritePropertyName("languageCode"u8); @@ -456,11 +111,12 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(definition.RevisionNumber); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing Definition for Version 1.1.0"); writer.WriteStartArray("citation"u8); foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) @@ -469,6 +125,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(definition.ClassKind.ToString()); writer.WritePropertyName("content"u8); @@ -481,6 +138,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -489,6 +147,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +156,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(definition.Iid); writer.WritePropertyName("languageCode"u8); @@ -511,11 +171,12 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(definition.RevisionNumber); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing Definition for Version 1.2.0"); writer.WriteStartArray("citation"u8); foreach(var citationItem in definition.Citation.OrderBy(x => x, this.GuidComparer)) @@ -524,6 +185,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(definition.ClassKind.ToString()); writer.WritePropertyName("content"u8); @@ -536,6 +198,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -544,6 +207,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -552,6 +216,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(definition.Iid); writer.WritePropertyName("languageCode"u8); @@ -566,13 +231,14 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(definition.RevisionNumber); writer.WritePropertyName("thingPreference"u8); writer.WriteStringValue(definition.ThingPreference); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Definition for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing Definition for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(definition.Actor.HasValue) @@ -592,6 +258,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(definition.ClassKind.ToString()); writer.WritePropertyName("content"u8); @@ -604,6 +271,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in definition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -612,6 +280,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in definition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -620,6 +289,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(definition.Iid); writer.WritePropertyName("languageCode"u8); @@ -634,6 +304,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(definition.RevisionNumber); writer.WritePropertyName("thingPreference"u8); @@ -645,6 +316,279 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "citation": + if(!AllowedVersionsPerProperty["citation"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("citation"u8); + + if(value is IEnumerable objectListCitation) + { + foreach(var citationItem in objectListCitation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(citationItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("content"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "example": + if(!AllowedVersionsPerProperty["example"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("example"u8); + + if(value is IEnumerable objectListExample) + { + foreach(var exampleItem in objectListExample.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(exampleItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("languageCode"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "note": + if(!AllowedVersionsPerProperty["note"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("note"u8); + + if(value is IEnumerable objectListNote) + { + foreach(var noteItem in objectListNote.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + } + + writer.WriteEndArray(); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the Definition"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "citation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "example", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "note", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs index f3f69c568..9242d2ad8 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DependentParameterTypeAssignmentSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,137 @@ namespace CDP4JsonSerializer /// public class DependentParameterTypeAssignmentSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not DependentParameterTypeAssignment dependentParameterTypeAssignment) + { + throw new ArgumentException("The thing shall be a DependentParameterTypeAssignment", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DependentParameterTypeAssignment since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DependentParameterTypeAssignment for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(dependentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DependentParameterTypeAssignment for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(dependentParameterTypeAssignment.Actor.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(dependentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +188,7 @@ public class DependentParameterTypeAssignmentSerializer : BaseThingSerializer, I /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +196,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,13 +214,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -110,14 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -135,14 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -160,13 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -184,13 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "measurementscale": - var allowedVersionsForMeasurementScale = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMeasurementScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["measurementScale"].Contains(requestedVersion)) { return; } @@ -208,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -233,13 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -257,13 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -281,13 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -310,131 +381,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not DependentParameterTypeAssignment dependentParameterTypeAssignment) - { - throw new ArgumentException("The thing shall be a DependentParameterTypeAssignment", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.2.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DependentParameterTypeAssignment since Version is below 1.2.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DependentParameterTypeAssignment for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.Iid); - writer.WritePropertyName("measurementScale"u8); - - if(dependentParameterTypeAssignment.MeasurementScale.HasValue) - { - writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DependentParameterTypeAssignment for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(dependentParameterTypeAssignment.Actor.HasValue) - { - writer.WriteStringValue(dependentParameterTypeAssignment.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in dependentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in dependentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.Iid); - writer.WritePropertyName("measurementScale"u8); - - if(dependentParameterTypeAssignment.MeasurementScale.HasValue) - { - writer.WriteStringValue(dependentParameterTypeAssignment.MeasurementScale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(dependentParameterTypeAssignment.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(dependentParameterTypeAssignment.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.2.0", "1.3.0" }}, + { "measurementScale", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs index 1df35a4f6..f44c6f3fe 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedQuantityKindSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,395 +51,437 @@ namespace CDP4JsonSerializer public class DerivedQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DerivedQuantityKind derivedQuantityKind) + { + throw new ArgumentException("The thing shall be a DerivedQuantityKind", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DerivedQuantityKind since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleScaleItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); - if(value is IEnumerable objectListCategory) + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteOrderedItem(quantityKindFactorItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "defaultscale": - var allowedVersionsForDefaultScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("defaultScale"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleScaleItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); - if(value is IEnumerable objectListDefinition) + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteOrderedItem(quantityKindFactorItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleScaleItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(quantityKindFactorItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedQuantityKind.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(derivedQuantityKind.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(derivedQuantityKind.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(derivedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "possiblescale": - var allowedVersionsForPossibleScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedQuantityKind.Name); writer.WriteStartArray("possibleScale"u8); - if(value is IEnumerable objectListPossibleScale) + foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleScaleItem); - } + writer.WriteStringValue(possibleScaleItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); + writer.WriteStartArray("quantityKindFactor"u8); + + foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(derivedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedQuantityKind.ThingPreference); break; - case "quantitydimensionsymbol": - var allowedVersionsForQuantityDimensionSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -446,77 +489,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "quantitykindfactor": - var allowedVersionsForQuantityKindFactor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForQuantityKindFactor.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("quantityKindFactor"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListQuantityKindFactor) + if(value is IEnumerable objectListAlias) { - foreach(var quantityKindFactorItem in objectListQuantityKindFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteOrderedItem(quantityKindFactorItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) { - writer.WriteNullValue(); + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } } - + + writer.WriteEndArray(); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -524,25 +543,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + case "defaultscale": + if(!AllowedVersionsPerProperty["defaultScale"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("defaultScale"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -550,411 +561,307 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedQuantityKind"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DerivedQuantityKind derivedQuantityKind) - { - throw new ArgumentException("The thing shall be a DerivedQuantityKind", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DerivedQuantityKind since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(derivedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(possibleScaleItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); - writer.WriteStartArray("quantityKindFactor"u8); - - foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteOrderedItem(quantityKindFactorItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(derivedQuantityKind.Symbol); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(derivedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(possibleScaleItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); - writer.WriteStartArray("quantityKindFactor"u8); - - foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(quantityKindFactorItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(derivedQuantityKind.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(derivedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "possiblescale": + if(!AllowedVersionsPerProperty["possibleScale"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("possibleScale"u8); - foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPossibleScale) { - writer.WriteStringValue(excludedPersonItem); + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "quantitydimensionsymbol": + if(!AllowedVersionsPerProperty["quantityDimensionSymbol"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + break; + case "quantitykindfactor": + if(!AllowedVersionsPerProperty["quantityKindFactor"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); writer.WriteStartArray("quantityKindFactor"u8); - foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListQuantityKindFactor) { - writer.WriteOrderedItem(quantityKindFactorItem); + foreach(var quantityKindFactorItem in objectListQuantityKindFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(quantityKindFactorItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(derivedQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(derivedQuantityKind.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedQuantityKind for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(derivedQuantityKind.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(derivedQuantityKind.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in derivedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(derivedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in derivedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in derivedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in derivedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(derivedQuantityKind.QuantityDimensionSymbol); - writer.WriteStartArray("quantityKindFactor"u8); - - foreach(var quantityKindFactorItem in derivedQuantityKind.QuantityKindFactor.OrderBy(x => x, this.OrderedItemComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteOrderedItem(quantityKindFactorItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(derivedQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(derivedQuantityKind.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedQuantityKind"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "quantityDimensionSymbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "quantityKindFactor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs index ecea0fcae..100c65783 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DerivedUnitSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,317 +51,341 @@ namespace CDP4JsonSerializer public class DerivedUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DerivedUnit derivedUnit) + { + throw new ArgumentException("The thing shall be a DerivedUnit", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DerivedUnit since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WriteStartArray("unitFactor"u8); - if(value is IEnumerable objectListAlias) + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteOrderedItem(unitFactorItem); } - + writer.WriteEndArray(); + break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WriteStartArray("unitFactor"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteOrderedItem(unitFactorItem); } - + writer.WriteEndArray(); + break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedUnit.ThingPreference); + writer.WriteStartArray("unitFactor"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(unitFactorItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DerivedUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(derivedUnit.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(derivedUnit.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(derivedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(derivedUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(derivedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(derivedUnit.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(derivedUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(derivedUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(derivedUnit.ThingPreference); + writer.WriteStartArray("unitFactor"u8); + + foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(unitFactorItem); } + writer.WriteEndArray(); + break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -368,49 +393,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -418,325 +429,248 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "unitfactor": - var allowedVersionsForUnitFactor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnitFactor.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("unitFactor"u8); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListUnitFactor) + if(value is IEnumerable objectListDefinition) { - foreach(var unitFactorItem in objectListUnitFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteOrderedItem(unitFactorItem); + writer.WriteStringValue(definitionItem); } } writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedUnit"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DerivedUnit derivedUnit) - { - throw new ArgumentException("The thing shall be a DerivedUnit", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DerivedUnit since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(definitionItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedUnit.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedUnit.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedUnit.ShortName); - writer.WriteStartArray("unitFactor"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteOrderedItem(unitFactorItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedUnit.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedUnit.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedUnit.ShortName); - writer.WriteStartArray("unitFactor"u8); - - foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(unitFactorItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedUnit.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedUnit.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(derivedUnit.ThingPreference); - writer.WriteStartArray("unitFactor"u8); - - foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(unitFactorItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DerivedUnit for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(derivedUnit.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(derivedUnit.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in derivedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(derivedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in derivedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in derivedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in derivedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var hyperLinkItem in derivedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "unitfactor": + if(!AllowedVersionsPerProperty["unitFactor"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(derivedUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(derivedUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(derivedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(derivedUnit.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(derivedUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(derivedUnit.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(derivedUnit.ThingPreference); writer.WriteStartArray("unitFactor"u8); - foreach(var unitFactorItem in derivedUnit.UnitFactor.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListUnitFactor) { - writer.WriteOrderedItem(unitFactorItem); + foreach(var unitFactorItem in objectListUnitFactor.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(unitFactorItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DerivedUnit"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unitFactor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs index 769a56402..f63fa3c49 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramCanvasSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,206 @@ namespace CDP4JsonSerializer /// public class DiagramCanvasSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not DiagramCanvas diagramCanvas) + { + throw new ArgumentException("The thing shall be a DiagramCanvas", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramCanvas since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramCanvas for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramCanvas for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramCanvas.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramCanvas for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(diagramCanvas.Actor.HasValue) + { + writer.WriteStringValue(diagramCanvas.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("diagramElement"u8); + + foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramCanvas.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramCanvas.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramCanvas.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramCanvas.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +257,7 @@ public class DiagramCanvasSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +265,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "bounds": - var allowedVersionsForBounds = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForBounds.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["bounds"].Contains(requestedVersion)) { return; } @@ -111,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -161,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "diagramelement": - var allowedVersionsForDiagramElement = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["diagramElement"].Contains(requestedVersion)) { return; } @@ -186,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -261,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -286,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -311,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -336,13 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -365,192 +486,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not DiagramCanvas diagramCanvas) - { - throw new ArgumentException("The thing shall be a DiagramCanvas", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DiagramCanvas since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.1.0"); - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(boundsItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramCanvas.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramCanvas.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramCanvas.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.2.0"); - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(boundsItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramCanvas.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramCanvas.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramCanvas.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramCanvas.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramCanvas for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(diagramCanvas.Actor.HasValue) - { - writer.WriteStringValue(diagramCanvas.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramCanvas.Bounds.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(boundsItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramCanvas.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(diagramCanvas.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramCanvas.DiagramElement.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramCanvas.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramCanvas.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramCanvas.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramCanvas.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramCanvas.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramCanvas.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramCanvas.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "bounds", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "diagramElement", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs index 54d41184c..bd83b5099 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramEdgeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,355 +51,352 @@ namespace CDP4JsonSerializer public class DiagramEdgeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DiagramEdge diagramEdge) + { + throw new ArgumentException("The thing shall be a DiagramEdge", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramEdge since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramEdge for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramEdge.DepictedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramEdge.DepictedThing.Value); } else { writer.WriteNullValue(); } - break; - case "bounds": - var allowedVersionsForBounds = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForBounds.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } - writer.WriteStartArray("bounds"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListBounds) + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(boundsItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); + + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(localStyleItem); } - break; - case "depictedthing": - var allowedVersionsForDepictedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); - if(!allowedVersionsForDepictedThing.Contains(requestedVersion)) + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(pointItem); } - writer.WritePropertyName("depictedThing"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramEdge.SharedStyle.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); break; - case "diagramelement": - var allowedVersionsForDiagramElement = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramEdge for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); - if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WriteStartArray("diagramElement"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); - if(value is IEnumerable objectListDiagramElement) + if(diagramEdge.DepictedThing.HasValue) { - foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } + writer.WriteStringValue(diagramEdge.DepictedThing.Value); } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(localStyleItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(pointItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramEdge.SharedStyle.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramEdge.ThingPreference); break; - case "localstyle": - var allowedVersionsForLocalStyle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramEdge for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - if(!allowedVersionsForLocalStyle.Contains(requestedVersion)) + if(diagramEdge.Actor.HasValue) { - return; + writer.WriteStringValue(diagramEdge.Actor.Value); } - - writer.WriteStartArray("localStyle"u8); - - if(value is IEnumerable objectListLocalStyle) + else { - foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(localStyleItem); - } + writer.WriteNullValue(); } - - writer.WriteEndArray(); - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramEdge.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramEdge.DepictedThing.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(diagramEdge.DepictedThing.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "point": - var allowedVersionsForPoint = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForPoint.Contains(requestedVersion)) + foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("point"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramEdge.Iid); + writer.WriteStartArray("localStyle"u8); - if(value is IEnumerable objectListPoint) + foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - foreach(var pointItem in objectListPoint.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(pointItem); - } + writer.WriteStringValue(localStyleItem); } - + writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramEdge.Name); + writer.WriteStartArray("point"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(pointItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramEdge.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramEdge.SharedStyle.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(diagramEdge.SharedStyle.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("source"u8); + writer.WriteStringValue(diagramEdge.Source); + writer.WritePropertyName("target"u8); + writer.WriteStringValue(diagramEdge.Target); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramEdge.ThingPreference); break; - case "sharedstyle": - var allowedVersionsForSharedStyle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForSharedStyle.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("sharedStyle"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -410,49 +408,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "source": - var allowedVersionsForSource = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSource.Contains(requestedVersion)) + case "bounds": + if(!AllowedVersionsPerProperty["bounds"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("source"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("bounds"u8); + + if(value is IEnumerable objectListBounds) { - writer.WriteNullValue(); + foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } } - + + writer.WriteEndArray(); break; - case "target": - var allowedVersionsForTarget = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTarget.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("target"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -460,23 +444,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "depictedthing": + if(!AllowedVersionsPerProperty["depictedThing"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("depictedThing"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -484,318 +462,268 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramEdge"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DiagramEdge diagramEdge) - { - throw new ArgumentException("The thing shall be a DiagramEdge", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DiagramEdge since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.1.0"); - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + case "diagramelement": + if(!AllowedVersionsPerProperty["diagramElement"].Contains(requestedVersion)) { - writer.WriteStringValue(boundsItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramEdge.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); + writer.WriteStartArray("diagramElement"u8); - if(diagramEdge.DepictedThing.HasValue) - { - writer.WriteStringValue(diagramEdge.DepictedThing.Value); - } - else + if(value is IEnumerable objectListDiagramElement) { - writer.WriteNullValue(); + foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } } - - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramElementItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramEdge.Iid); - writer.WriteStartArray("localStyle"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(localStyleItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramEdge.Name); - writer.WriteStartArray("point"u8); - - foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteOrderedItem(pointItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramEdge.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); - - if(diagramEdge.SharedStyle.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.SharedStyle.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("source"u8); - writer.WriteStringValue(diagramEdge.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(diagramEdge.Target); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.2.0"); - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + case "localstyle": + if(!AllowedVersionsPerProperty["localStyle"].Contains(requestedVersion)) { - writer.WriteStringValue(boundsItem); + return; } + writer.WriteStartArray("localStyle"u8); + + if(value is IEnumerable objectListLocalStyle) + { + foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } + } + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramEdge.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(diagramEdge.DepictedThing.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.DepictedThing.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramElementItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramEdge.Iid); - writer.WriteStartArray("localStyle"u8); - - foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "point": + if(!AllowedVersionsPerProperty["point"].Contains(requestedVersion)) { - writer.WriteStringValue(localStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramEdge.Name); writer.WriteStartArray("point"u8); - foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListPoint) { - writer.WriteOrderedItem(pointItem); + foreach(var pointItem in objectListPoint.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pointItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramEdge.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(diagramEdge.SharedStyle.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.SharedStyle.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("source"u8); - writer.WriteStringValue(diagramEdge.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(diagramEdge.Target); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramEdge.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramEdge for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "sharedstyle": + if(!AllowedVersionsPerProperty["sharedStyle"].Contains(requestedVersion)) + { + return; + } - if(diagramEdge.Actor.HasValue) + writer.WritePropertyName("sharedStyle"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramEdge.Bounds.OrderBy(x => x, this.GuidComparer)) + break; + case "source": + if(!AllowedVersionsPerProperty["source"].Contains(requestedVersion)) { - writer.WriteStringValue(boundsItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramEdge.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); - - if(diagramEdge.DepictedThing.HasValue) + writer.WritePropertyName("source"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.DepictedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramEdge.DiagramElement.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramEdge.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "target": + if(!AllowedVersionsPerProperty["target"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramEdge.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("target"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramEdge.Iid); - writer.WriteStartArray("localStyle"u8); - - foreach(var localStyleItem in diagramEdge.LocalStyle.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(localStyleItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramEdge.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramEdge.Name); - writer.WriteStartArray("point"u8); - - foreach(var pointItem in diagramEdge.Point.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteOrderedItem(pointItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramEdge.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); - - if(diagramEdge.SharedStyle.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(diagramEdge.SharedStyle.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("source"u8); - writer.WriteStringValue(diagramEdge.Source); - writer.WritePropertyName("target"u8); - writer.WriteStringValue(diagramEdge.Target); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramEdge.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramEdge"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "bounds", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "depictedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "diagramElement", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "localStyle", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "point", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sharedStyle", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "source", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "target", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs index 246cec687..8c6f2971d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DiagramObjectSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,109 +51,107 @@ namespace CDP4JsonSerializer public class DiagramObjectSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DiagramObject diagramObject) + { + throw new ArgumentException("The thing shall be a DiagramObject", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DiagramObject since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramObject for Version 1.1.0"); + writer.WriteStartArray("bounds"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramObject.DepictedThing.Value); } else { writer.WriteNullValue(); } - break; - case "bounds": - var allowedVersionsForBounds = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForBounds.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } - writer.WriteStartArray("bounds"u8); - - if(value is IEnumerable objectListBounds) - { - foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(boundsItem); - } - } - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "depictedthing": - var allowedVersionsForDepictedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); - if(!allowedVersionsForDepictedThing.Contains(requestedVersion)) + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(localStyleItem); } - writer.WritePropertyName("depictedThing"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramObject.SharedStyle.Value); } else { @@ -160,249 +159,221 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "diagramelement": - var allowedVersionsForDiagramElement = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramObject for Version 1.2.0"); + writer.WriteStartArray("bounds"u8); - if(!allowedVersionsForDiagramElement.Contains(requestedVersion)) + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WriteStartArray("diagramElement"u8); - - if(value is IEnumerable objectListDiagramElement) - { - foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramElementItem); - } - } - writer.WriteEndArray(); - break; - case "documentation": - var allowedVersionsForDocumentation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDocumentation.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("documentation"u8); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(diagramObject.DepictedThing.Value); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(localStyleItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(diagramObject.SharedStyle.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramObject.ThingPreference); break; - case "localstyle": - var allowedVersionsForLocalStyle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DiagramObject for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - if(!allowedVersionsForLocalStyle.Contains(requestedVersion)) + if(diagramObject.Actor.HasValue) { - return; + writer.WriteStringValue(diagramObject.Actor.Value); } - - writer.WriteStartArray("localStyle"u8); - - if(value is IEnumerable objectListLocalStyle) + else { - foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(localStyleItem); - } + writer.WriteNullValue(); } - - writer.WriteEndArray(); - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + writer.WriteStartArray("bounds"u8); + + foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(boundsItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(diagramObject.ClassKind.ToString()); + writer.WritePropertyName("depictedThing"u8); + + if(diagramObject.DepictedThing.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(diagramObject.DepictedThing.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("diagramElement"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramElementItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("documentation"u8); + writer.WriteStringValue(diagramObject.Documentation); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "resolution": - var allowedVersionsForResolution = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(diagramObject.Iid); + writer.WriteStartArray("localStyle"u8); - if(!allowedVersionsForResolution.Contains(requestedVersion)) + foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(localStyleItem); } - writer.WritePropertyName("resolution"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(diagramObject.Name); + writer.WritePropertyName("resolution"u8); + writer.WriteNumberValue(diagramObject.Resolution); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(diagramObject.RevisionNumber); + writer.WritePropertyName("sharedStyle"u8); + + if(diagramObject.SharedStyle.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteStringValue(diagramObject.SharedStyle.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(diagramObject.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -410,24 +381,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "sharedstyle": - var allowedVersionsForSharedStyle = new List + case "bounds": + if(!AllowedVersionsPerProperty["bounds"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("bounds"u8); - if(!allowedVersionsForSharedStyle.Contains(requestedVersion)) + if(value is IEnumerable objectListBounds) + { + foreach(var boundsItem in objectListBounds.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(boundsItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("sharedStyle"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,23 +417,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "depictedthing": + if(!AllowedVersionsPerProperty["depictedThing"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("depictedThing"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -459,108 +435,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramObject"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DiagramObject diagramObject) - { - throw new ArgumentException("The thing shall be a DiagramObject", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DiagramObject since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); + case "diagramelement": + if(!AllowedVersionsPerProperty["diagramElement"].Contains(requestedVersion)) + { + return; + } - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.1.0"); - writer.WriteStartArray("bounds"u8); + writer.WriteStartArray("diagramElement"u8); - foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDiagramElement) { - writer.WriteStringValue(boundsItem); + foreach(var diagramElementItem in objectListDiagramElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramElementItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramObject.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); + break; + case "documentation": + if(!AllowedVersionsPerProperty["documentation"].Contains(requestedVersion)) + { + return; + } - if(diagramObject.DepictedThing.HasValue) + writer.WritePropertyName("documentation"u8); + + if(value != null) { - writer.WriteStringValue(diagramObject.DepictedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramElementItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("documentation"u8); - writer.WriteStringValue(diagramObject.Documentation); writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramObject.Iid); - writer.WriteStartArray("localStyle"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(localStyleItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramObject.Name); - writer.WritePropertyName("resolution"u8); - writer.WriteNumberValue(diagramObject.Resolution); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramObject.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(diagramObject.SharedStyle.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(diagramObject.SharedStyle.Value); + writer.WriteStringValue((Guid)value); } else { @@ -568,185 +525,159 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.2.0"); - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + case "localstyle": + if(!AllowedVersionsPerProperty["localStyle"].Contains(requestedVersion)) { - writer.WriteStringValue(boundsItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramObject.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); + writer.WriteStartArray("localStyle"u8); - if(diagramObject.DepictedThing.HasValue) - { - writer.WriteStringValue(diagramObject.DepictedThing.Value); - } - else + if(value is IEnumerable objectListLocalStyle) { - writer.WriteNullValue(); + foreach(var localStyleItem in objectListLocalStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(localStyleItem); + } } - - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + + writer.WriteEndArray(); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramElementItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("documentation"u8); - writer.WriteStringValue(diagramObject.Documentation); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramObject.Iid); - writer.WriteStartArray("localStyle"u8); - - foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(localStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramObject.Name); - writer.WritePropertyName("resolution"u8); - writer.WriteNumberValue(diagramObject.Resolution); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramObject.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); - - if(diagramObject.SharedStyle.HasValue) + + if(value != null) { - writer.WriteStringValue(diagramObject.SharedStyle.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramObject.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DiagramObject for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "resolution": + if(!AllowedVersionsPerProperty["resolution"].Contains(requestedVersion)) + { + return; + } - if(diagramObject.Actor.HasValue) + writer.WritePropertyName("resolution"u8); + + if(value != null) { - writer.WriteStringValue(diagramObject.Actor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("bounds"u8); - - foreach(var boundsItem in diagramObject.Bounds.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(boundsItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(diagramObject.ClassKind.ToString()); - writer.WritePropertyName("depictedThing"u8); - - if(diagramObject.DepictedThing.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(diagramObject.DepictedThing.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("diagramElement"u8); - - foreach(var diagramElementItem in diagramObject.DiagramElement.OrderBy(x => x, this.GuidComparer)) + break; + case "sharedstyle": + if(!AllowedVersionsPerProperty["sharedStyle"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramElementItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("documentation"u8); - writer.WriteStringValue(diagramObject.Documentation); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in diagramObject.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("sharedStyle"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in diagramObject.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(diagramObject.Iid); - writer.WriteStartArray("localStyle"u8); - - foreach(var localStyleItem in diagramObject.LocalStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(localStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(diagramObject.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(diagramObject.Name); - writer.WritePropertyName("resolution"u8); - writer.WriteNumberValue(diagramObject.Resolution); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(diagramObject.RevisionNumber); - writer.WritePropertyName("sharedStyle"u8); - - if(diagramObject.SharedStyle.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(diagramObject.SharedStyle.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(diagramObject.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DiagramObject"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "bounds", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "depictedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "diagramElement", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "documentation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "localStyle", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "resolution", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sharedStyle", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs index 150af9e1c..487b8d342 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainFileStoreSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,253 @@ namespace CDP4JsonSerializer /// public class DomainFileStoreSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not DomainFileStore domainFileStore) + { + throw new ArgumentException("The thing shall be a DomainFileStore", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of DomainFileStore since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DomainFileStore for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DomainFileStore for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DomainFileStore for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainFileStore.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DomainFileStore for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(domainFileStore.Actor.HasValue) + { + writer.WriteStringValue(domainFileStore.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainFileStore.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("file"u8); + + foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("folder"u8); + + foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(folderItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainFileStore.Iid); + writer.WritePropertyName("isHidden"u8); + writer.WriteBooleanValue(domainFileStore.IsHidden); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainFileStore.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(domainFileStore.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainFileStore.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainFileStore.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +304,7 @@ public class DomainFileStoreSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +312,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +330,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +348,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -138,14 +366,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +384,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "file": - var allowedVersionsForFile = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFile.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["file"].Contains(requestedVersion)) { return; } @@ -214,15 +420,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "folder": - var allowedVersionsForFolder = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFolder.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["folder"].Contains(requestedVersion)) { return; } @@ -240,15 +438,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -266,15 +456,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "ishidden": - var allowedVersionsForIsHidden = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsHidden.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isHidden"].Contains(requestedVersion)) { return; } @@ -292,14 +474,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -317,15 +492,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -343,15 +510,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -369,15 +528,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -395,13 +546,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -424,237 +569,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not DomainFileStore domainFileStore) - { - throw new ArgumentException("The thing shall be a DomainFileStore", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DomainFileStore since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainFileStore.Iid); - writer.WritePropertyName("isHidden"u8); - writer.WriteBooleanValue(domainFileStore.IsHidden); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(domainFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainFileStore.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainFileStore.Iid); - writer.WritePropertyName("isHidden"u8); - writer.WriteBooleanValue(domainFileStore.IsHidden); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(domainFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainFileStore.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainFileStore.Iid); - writer.WritePropertyName("isHidden"u8); - writer.WriteBooleanValue(domainFileStore.IsHidden); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(domainFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainFileStore.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainFileStore.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DomainFileStore for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(domainFileStore.Actor.HasValue) - { - writer.WriteStringValue(domainFileStore.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainFileStore.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(domainFileStore.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainFileStore.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainFileStore.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("file"u8); - - foreach(var fileItem in domainFileStore.File.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("folder"u8); - - foreach(var folderItem in domainFileStore.Folder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(folderItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainFileStore.Iid); - writer.WritePropertyName("isHidden"u8); - writer.WriteBooleanValue(domainFileStore.IsHidden); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainFileStore.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainFileStore.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(domainFileStore.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainFileStore.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainFileStore.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "file", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "folder", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isHidden", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs index 39729d22c..0b6e75b6d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseGroupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,341 @@ namespace CDP4JsonSerializer public class DomainOfExpertiseGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DomainOfExpertiseGroup domainOfExpertiseGroup) + { + throw new ArgumentException("The thing shall be a DomainOfExpertiseGroup", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertiseGroup since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertiseGroup for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("domain"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertiseGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("domain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "domain": - var allowedVersionsForDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDomain.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("domain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDomain) + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertiseGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("domain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertiseGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(domainOfExpertiseGroup.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(domainOfExpertiseGroup.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("domain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertiseGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,49 +393,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -444,299 +429,248 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertiseGroup"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DomainOfExpertiseGroup domainOfExpertiseGroup) - { - throw new ArgumentException("The thing shall be a DomainOfExpertiseGroup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertiseGroup since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + break; + case "domain": + if(!AllowedVersionsPerProperty["domain"].Contains(requestedVersion)) { - writer.WriteStringValue(domainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("domain"u8); - foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDomain) { - writer.WriteStringValue(hyperLinkItem); + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(definitionItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(domainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(domainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertiseGroup for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(domainOfExpertiseGroup.Actor.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(domainOfExpertiseGroup.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertiseGroup.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertiseGroup.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in domainOfExpertiseGroup.Domain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(domainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainOfExpertiseGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var excludedPersonItem in domainOfExpertiseGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var hyperLinkItem in domainOfExpertiseGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertiseGroup.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertiseGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertiseGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ShortName); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainOfExpertiseGroup.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertiseGroup"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "domain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs index d5fe53e4e..27e14bd41 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/DomainOfExpertiseSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,341 @@ namespace CDP4JsonSerializer public class DomainOfExpertiseSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not DomainOfExpertise domainOfExpertise) + { + throw new ArgumentException("The thing shall be a DomainOfExpertise", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertise since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertise for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertise for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertise for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertise.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing DomainOfExpertise for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(domainOfExpertise.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(domainOfExpertise.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(domainOfExpertise.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(domainOfExpertise.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(domainOfExpertise.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(domainOfExpertise.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(domainOfExpertise.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,49 +393,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -444,299 +447,230 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertise"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not DomainOfExpertise domainOfExpertise) - { - throw new ArgumentException("The thing shall be a DomainOfExpertise", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of DomainOfExpertise since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("definition"u8); - foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(categoryItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(hyperLinkItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertise.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertise.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertise.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertise.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(excludedDomainItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertise.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertise.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertise.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertise.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertise.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertise.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertise.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertise.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainOfExpertise.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing DomainOfExpertise for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } - if(domainOfExpertise.Actor.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(domainOfExpertise.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in domainOfExpertise.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in domainOfExpertise.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(domainOfExpertise.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in domainOfExpertise.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in domainOfExpertise.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in domainOfExpertise.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in domainOfExpertise.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(domainOfExpertise.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(domainOfExpertise.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(domainOfExpertise.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(domainOfExpertise.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(domainOfExpertise.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(domainOfExpertise.ShortName); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(domainOfExpertise.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the DomainOfExpertise"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs index 79cf4552d..dfb690303 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementDefinitionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,560 +51,355 @@ namespace CDP4JsonSerializer public class ElementDefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ElementDefinition elementDefinition) + { + throw new ArgumentException("The thing shall be a ElementDefinition", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ElementDefinition since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ElementDefinition for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(containedElementItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListAlias) + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); - if(value is IEnumerable objectListCategory) + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(parameterItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("parameterGroup"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterGroupItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("referencedElement"u8); + + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(referencedElementItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); break; - case "containedelement": - var allowedVersionsForContainedElement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ElementDefinition for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForContainedElement.Contains(requestedVersion)) + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("containedElement"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListContainedElement) + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var containedElementItem in objectListContainedElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(containedElementItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(containedElementItem); } + writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(parameterItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("parameterGroup"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterGroupItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("referencedElement"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(referencedElementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ElementDefinition for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementDefinition.ClassKind.ToString()); + writer.WriteStartArray("containedElement"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(containedElementItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "organizationalparticipant": - var allowedVersionsForOrganizationalParticipant = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForOrganizationalParticipant.Contains(requestedVersion)) + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("organizationalParticipant"u8); - - if(value is IEnumerable objectListOrganizationalParticipant) - { - foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(organizationalParticipantItem); - } - } - writer.WriteEndArray(); - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("owner"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "parameter": - var allowedVersionsForParameter = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForParameter.Contains(requestedVersion)) + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("parameter"u8); - - if(value is IEnumerable objectListParameter) - { - foreach(var parameterItem in objectListParameter.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterItem); - } - } - writer.WriteEndArray(); - break; - case "parametergroup": - var allowedVersionsForParameterGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WriteStartArray("organizationalParticipant"u8); - if(!allowedVersionsForParameterGroup.Contains(requestedVersion)) + foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(organizationalParticipantItem); } - writer.WriteStartArray("parameterGroup"u8); - - if(value is IEnumerable objectListParameterGroup) - { - foreach(var parameterGroupItem in objectListParameterGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterGroupItem); - } - } - writer.WriteEndArray(); - break; - case "referencedelement": - var allowedVersionsForReferencedElement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); - if(!allowedVersionsForReferencedElement.Contains(requestedVersion)) + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterItem); } - writer.WriteStartArray("referencedElement"u8); - - if(value is IEnumerable objectListReferencedElement) - { - foreach(var referencedElementItem in objectListReferencedElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referencedElementItem); - } - } - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("parameterGroup"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterGroupItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("referencedElement"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referencedElementItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementDefinition.ThingPreference); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ElementDefinition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + if(elementDefinition.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(elementDefinition.Actor.Value); } else { writer.WriteNullValue(); } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementDefinition"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ElementDefinition elementDefinition) - { - throw new ArgumentException("The thing shall be a ElementDefinition", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ElementDefinition since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.0.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -612,6 +408,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("category"u8); foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) @@ -620,6 +417,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(elementDefinition.ClassKind.ToString()); writer.WriteStartArray("containedElement"u8); @@ -630,6 +428,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) @@ -638,377 +437,497 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + + writer.WriteStartArray("excludedDomain"u8); - foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue(excludedDomainItem); } writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementDefinition.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementDefinition.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementDefinition.Owner); - writer.WriteStartArray("parameter"u8); + + writer.WriteStartArray("excludedPerson"u8); - foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); - writer.WriteStartArray("parameterGroup"u8); + + writer.WriteStartArray("hyperLink"u8); - foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterGroupItem); + writer.WriteStringValue(hyperLinkItem); } writer.WriteEndArray(); - writer.WriteStartArray("referencedElement"u8); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementDefinition.Name); + writer.WriteStartArray("organizationalParticipant"u8); - foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(referencedElementItem); + writer.WriteStringValue(organizationalParticipantItem); } writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementDefinition.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementDefinition.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.1.0"); - writer.WriteStartArray("alias"u8); + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementDefinition.Owner); + writer.WriteStartArray("parameter"u8); - foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(parameterItem); } writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + + writer.WriteStartArray("parameterGroup"u8); - foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(parameterGroupItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementDefinition.ClassKind.ToString()); - writer.WriteStartArray("containedElement"u8); + + writer.WriteStartArray("referencedElement"u8); - foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(containedElementItem); + writer.WriteStringValue(referencedElementItem); } writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementDefinition.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementDefinition.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("actor"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementDefinition.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementDefinition.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementDefinition.Owner); - writer.WriteStartArray("parameter"u8); + writer.WriteStartArray("alias"u8); - foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(parameterItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("parameterGroup"u8); - - foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterGroupItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referencedElement"u8); + writer.WriteStartArray("category"u8); - foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListCategory) { - writer.WriteStringValue(referencedElementItem); + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementDefinition.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementDefinition.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "containedelement": + if(!AllowedVersionsPerProperty["containedElement"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementDefinition.ClassKind.ToString()); writer.WriteStartArray("containedElement"u8); - foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListContainedElement) { - writer.WriteStringValue(containedElementItem); + foreach(var containedElementItem in objectListContainedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(containedElementItem); + } } - + writer.WriteEndArray(); + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("definition"u8); - foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementDefinition.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementDefinition.Name); - writer.WriteStartArray("organizationalParticipant"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(organizationalParticipantItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementDefinition.Owner); - writer.WriteStartArray("parameter"u8); + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } - foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("parameterGroup"u8); + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + break; + case "organizationalparticipant": + if(!AllowedVersionsPerProperty["organizationalParticipant"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterGroupItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referencedElement"u8); + writer.WriteStartArray("organizationalParticipant"u8); - foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListOrganizationalParticipant) { - writer.WriteStringValue(referencedElementItem); + foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementDefinition.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementDefinition.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(elementDefinition.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ElementDefinition for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) + { + return; + } - if(elementDefinition.Actor.HasValue) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(elementDefinition.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "parameter": + if(!AllowedVersionsPerProperty["parameter"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("parameter"u8); - foreach(var categoryItem in elementDefinition.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameter) { - writer.WriteStringValue(categoryItem); + foreach(var parameterItem in objectListParameter.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementDefinition.ClassKind.ToString()); - writer.WriteStartArray("containedElement"u8); - - foreach(var containedElementItem in elementDefinition.ContainedElement.OrderBy(x => x, this.GuidComparer)) + break; + case "parametergroup": + if(!AllowedVersionsPerProperty["parameterGroup"].Contains(requestedVersion)) { - writer.WriteStringValue(containedElementItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("parameterGroup"u8); - foreach(var definitionItem in elementDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterGroup) { - writer.WriteStringValue(definitionItem); + foreach(var parameterGroupItem in objectListParameterGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterGroupItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in elementDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "referencedelement": + if(!AllowedVersionsPerProperty["referencedElement"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("referencedElement"u8); - foreach(var excludedPersonItem in elementDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListReferencedElement) { - writer.WriteStringValue(excludedPersonItem); + foreach(var referencedElementItem in objectListReferencedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedElementItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementDefinition.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementDefinition.Name); - writer.WriteStartArray("organizationalParticipant"u8); - - foreach(var organizationalParticipantItem in elementDefinition.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(organizationalParticipantItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementDefinition.Owner); - writer.WriteStartArray("parameter"u8); - - foreach(var parameterItem in elementDefinition.Parameter.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(parameterItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("parameterGroup"u8); - - foreach(var parameterGroupItem in elementDefinition.ParameterGroup.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterGroupItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referencedElement"u8); + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var referencedElementItem in elementDefinition.ReferencedElement.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(referencedElementItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementDefinition.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementDefinition.ShortName); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(elementDefinition.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementDefinition"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containedElement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "organizationalParticipant", new []{ "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameter", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterGroup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedElement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs index 1653d0d9a..b2751cf4f 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ElementUsageSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,391 +51,425 @@ namespace CDP4JsonSerializer public class ElementUsageSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ElementUsage elementUsage) + { + throw new ArgumentException("The thing shall be a ElementUsage", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ElementUsage since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ElementUsage for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludeOption"u8); - if(value is IEnumerable objectListAlias) + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(excludeOptionItem); } - + writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); - if(value is IEnumerable objectListCategory) + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(parameterOverrideItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ElementUsage for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "elementdefinition": - var allowedVersionsForElementDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludeOption"u8); - if(!allowedVersionsForElementDefinition.Contains(requestedVersion)) + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludeOptionItem); } - writer.WritePropertyName("elementDefinition"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(parameterOverrideItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ElementUsage for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludeoption": - var allowedVersionsForExcludeOption = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludeOption.Contains(requestedVersion)) + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludeOption"u8); - if(value is IEnumerable objectListExcludeOption) + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludeOptionItem); - } - } - - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; + writer.WriteStringValue(excludeOptionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterOverrideItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementUsage.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ElementUsage for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(elementUsage.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(elementUsage.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "interfaceend": - var allowedVersionsForInterfaceEnd = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForInterfaceEnd.Contains(requestedVersion)) + foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("interfaceEnd"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((InterfaceEndKind)value).ToString()); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(elementUsage.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("elementDefinition"u8); + writer.WriteStringValue(elementUsage.ElementDefinition); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludeOption"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludeOptionItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(elementUsage.Iid); + writer.WritePropertyName("interfaceEnd"u8); + writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(elementUsage.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(elementUsage.Owner); + writer.WriteStartArray("parameterOverride"u8); + + foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(parameterOverrideItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(elementUsage.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(elementUsage.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(elementUsage.ThingPreference); break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -446,51 +481,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "parameteroverride": - var allowedVersionsForParameterOverride = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterOverride.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("parameterOverride"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListParameterOverride) + if(value is IEnumerable objectListAlias) { - foreach(var parameterOverrideItem in objectListParameterOverride.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterOverrideItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -498,25 +535,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForShortName.Contains(requestedVersion)) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "elementdefinition": + if(!AllowedVersionsPerProperty["elementDefinition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("elementDefinition"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -524,403 +571,270 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue((string)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementUsage"); - } - } + writer.WriteStartArray("excludedPerson"u8); - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ElementUsage elementUsage) - { - throw new ArgumentException("The thing shall be a ElementUsage", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ElementUsage since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementUsage.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeoption": + if(!AllowedVersionsPerProperty["excludeOption"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("elementDefinition"u8); - writer.WriteStringValue(elementUsage.ElementDefinition); writer.WriteStartArray("excludeOption"u8); - foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludeOption) { - writer.WriteStringValue(excludeOptionItem); + foreach(var excludeOptionItem in objectListExcludeOption.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludeOptionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementUsage.Iid); - writer.WritePropertyName("interfaceEnd"u8); - writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementUsage.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementUsage.Owner); - writer.WriteStartArray("parameterOverride"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(parameterOverrideItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementUsage.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementUsage.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementUsage.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("elementDefinition"u8); - writer.WriteStringValue(elementUsage.ElementDefinition); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "interfaceend": + if(!AllowedVersionsPerProperty["interfaceEnd"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("interfaceEnd"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((InterfaceEndKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludeOption"u8); - - foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludeOptionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementUsage.Iid); - writer.WritePropertyName("interfaceEnd"u8); - writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementUsage.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementUsage.Owner); - writer.WriteStartArray("parameterOverride"u8); - - foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(parameterOverrideItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementUsage.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementUsage.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementUsage.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("elementDefinition"u8); - writer.WriteStringValue(elementUsage.ElementDefinition); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludeOption"u8); - - foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludeOptionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "parameteroverride": + if(!AllowedVersionsPerProperty["parameterOverride"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementUsage.Iid); - writer.WritePropertyName("interfaceEnd"u8); - writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementUsage.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementUsage.Owner); writer.WriteStartArray("parameterOverride"u8); - foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterOverride) { - writer.WriteStringValue(parameterOverrideItem); + foreach(var parameterOverrideItem in objectListParameterOverride.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterOverrideItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementUsage.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementUsage.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(elementUsage.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ElementUsage for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(elementUsage.Actor.HasValue) - { - writer.WriteStringValue(elementUsage.Actor.Value); - } - else + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in elementUsage.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in elementUsage.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(elementUsage.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in elementUsage.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("elementDefinition"u8); - writer.WriteStringValue(elementUsage.ElementDefinition); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in elementUsage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in elementUsage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludeOption"u8); - - foreach(var excludeOptionItem in elementUsage.ExcludeOption.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludeOptionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in elementUsage.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(elementUsage.Iid); - writer.WritePropertyName("interfaceEnd"u8); - writer.WriteStringValue(elementUsage.InterfaceEnd.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(elementUsage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(elementUsage.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(elementUsage.Owner); - writer.WriteStartArray("parameterOverride"u8); - - foreach(var parameterOverrideItem in elementUsage.ParameterOverride.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(parameterOverrideItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(elementUsage.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(elementUsage.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(elementUsage.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ElementUsage"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "elementDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludeOption", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "interfaceEnd", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterOverride", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs index 806e68b7f..917f19f7c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EmailAddressSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class EmailAddressSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not EmailAddress emailAddress) + { + throw new ArgumentException("The thing shall be a EmailAddress", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of EmailAddress since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing EmailAddress for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EmailAddress for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EmailAddress for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(emailAddress.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EmailAddress for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(emailAddress.Actor.HasValue) + { + writer.WriteStringValue(emailAddress.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(emailAddress.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(emailAddress.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(emailAddress.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(emailAddress.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(emailAddress.Value); + writer.WritePropertyName("vcardType"u8); + writer.WriteStringValue(emailAddress.VcardType.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class EmailAddressSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,13 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -263,15 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -289,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "vcardtype": - var allowedVersionsForVcardType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForVcardType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["vcardType"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not EmailAddress emailAddress) - { - throw new ArgumentException("The thing shall be a EmailAddress", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EmailAddress since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(emailAddress.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(emailAddress.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(emailAddress.RevisionNumber); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(emailAddress.Value); - writer.WritePropertyName("vcardType"u8); - writer.WriteStringValue(emailAddress.VcardType.ToString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(emailAddress.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(emailAddress.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(emailAddress.RevisionNumber); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(emailAddress.Value); - writer.WritePropertyName("vcardType"u8); - writer.WriteStringValue(emailAddress.VcardType.ToString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(emailAddress.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(emailAddress.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(emailAddress.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(emailAddress.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(emailAddress.Value); - writer.WritePropertyName("vcardType"u8); - writer.WriteStringValue(emailAddress.VcardType.ToString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EmailAddress for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(emailAddress.Actor.HasValue) - { - writer.WriteStringValue(emailAddress.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(emailAddress.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in emailAddress.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in emailAddress.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(emailAddress.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(emailAddress.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(emailAddress.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(emailAddress.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(emailAddress.Value); - writer.WritePropertyName("vcardType"u8); - writer.WriteStringValue(emailAddress.VcardType.ToString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "vcardType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs index b2c6ba21d..86eb793bd 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataDiscussionItemSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,197 @@ namespace CDP4JsonSerializer /// public class EngineeringModelDataDiscussionItemSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not EngineeringModelDataDiscussionItem engineeringModelDataDiscussionItem) + { + throw new ArgumentException("The thing shall be a EngineeringModelDataDiscussionItem", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataDiscussionItem since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataDiscussionItem for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataDiscussionItem for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataDiscussionItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModelDataDiscussionItem.Actor.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +248,7 @@ public class EngineeringModelDataDiscussionItemSerializer : BaseThingSerializer, /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +256,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +274,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +292,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +310,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +328,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +346,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +364,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +382,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -261,14 +400,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -286,14 +418,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +436,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "replyto": - var allowedVersionsForReplyTo = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReplyTo.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["replyTo"].Contains(requestedVersion)) { return; } @@ -336,14 +454,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,13 +472,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -390,189 +495,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not EngineeringModelDataDiscussionItem engineeringModelDataDiscussionItem) - { - throw new ArgumentException("The thing shall be a EngineeringModelDataDiscussionItem", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataDiscussionItem since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataDiscussionItem for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(engineeringModelDataDiscussionItem.Actor.HasValue) - { - writer.WriteStringValue(engineeringModelDataDiscussionItem.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(engineeringModelDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(engineeringModelDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataDiscussionItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelDataDiscussionItem.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "replyTo", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs index 58c900552..fc7c747ee 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelDataNoteSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,251 @@ namespace CDP4JsonSerializer /// public class EngineeringModelDataNoteSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not EngineeringModelDataNote engineeringModelDataNote) + { + throw new ArgumentException("The thing shall be a EngineeringModelDataNote", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataNote for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataNote for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelDataNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModelDataNote.Actor.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(engineeringModelDataNote.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(engineeringModelDataNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelDataNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(engineeringModelDataNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) + { + writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelDataNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +302,7 @@ public class EngineeringModelDataNoteSerializer : BaseThingSerializer, IThingSer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +310,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +328,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +346,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +364,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +382,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +400,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { return; } @@ -211,14 +418,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -236,14 +436,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -261,14 +454,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +472,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -311,14 +490,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -336,14 +508,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { return; } @@ -361,14 +526,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { return; } @@ -386,14 +544,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -411,13 +562,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -440,237 +585,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not EngineeringModelDataNote engineeringModelDataNote) - { - throw new ArgumentException("The thing shall be a EngineeringModelDataNote", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelDataNote since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataNote.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) - { - writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataNote.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) - { - writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelDataNote.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelDataNote for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(engineeringModelDataNote.Actor.HasValue) - { - writer.WriteStringValue(engineeringModelDataNote.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(engineeringModelDataNote.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelDataNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(engineeringModelDataNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(engineeringModelDataNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in engineeringModelDataNote.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelDataNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelDataNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelDataNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(engineeringModelDataNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelDataNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(engineeringModelDataNote.PrimaryAnnotatedThing.HasValue) - { - writer.WriteStringValue(engineeringModelDataNote.PrimaryAnnotatedThing.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in engineeringModelDataNote.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelDataNote.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelDataNote.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs index e1215330c..307e41233 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,366 +51,378 @@ namespace CDP4JsonSerializer public class EngineeringModelSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not EngineeringModel engineeringModel) + { + throw new ArgumentException("The thing shall be a EngineeringModel", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModel since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModel for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(commonFileStoreItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); + + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(iterationItem); } - break; - case "book": - var allowedVersionsForBook = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); - if(!allowedVersionsForBook.Contains(requestedVersion)) + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(logEntryItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModel for Version 1.1.0"); writer.WriteStartArray("book"u8); - if(value is IEnumerable objectListBook) + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var bookItem in objectListBook.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(bookItem); - } + writer.WriteOrderedItem(bookItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(commonFileStoreItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "commonfilestore": - var allowedVersionsForCommonFileStore = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForCommonFileStore.Contains(requestedVersion)) + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("commonFileStore"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("genericNote"u8); - if(value is IEnumerable objectListCommonFileStore) + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) { - foreach(var commonFileStoreItem in objectListCommonFileStore.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(commonFileStoreItem); - } + writer.WriteStringValue(genericNoteItem); } - + writer.WriteEndArray(); - break; - case "engineeringmodelsetup": - var allowedVersionsForEngineeringModelSetup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); - if(!allowedVersionsForEngineeringModelSetup.Contains(requestedVersion)) + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(iterationItem); } - writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(logEntryItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("modellingAnnotation"u8); + + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(modellingAnnotationItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModel for Version 1.2.0"); + writer.WriteStartArray("book"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(bookItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(commonFileStoreItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "genericnote": - var allowedVersionsForGenericNote = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("genericNote"u8); - if(!allowedVersionsForGenericNote.Contains(requestedVersion)) + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(genericNoteItem); } - writer.WriteStartArray("genericNote"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); - if(value is IEnumerable objectListGenericNote) + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) { - foreach(var genericNoteItem in objectListGenericNote.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(genericNoteItem); - } + writer.WriteStringValue(iterationItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List + + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(logEntryItem); + } - if(!allowedVersionsForIid.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WriteStartArray("modellingAnnotation"u8); + + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(modellingAnnotationItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModel.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModel for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(engineeringModel.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(engineeringModel.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "iteration": - var allowedVersionsForIteration = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("book"u8); - if(!allowedVersionsForIteration.Contains(requestedVersion)) + foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(bookItem); } - writer.WriteStartArray("iteration"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModel.ClassKind.ToString()); + writer.WriteStartArray("commonFileStore"u8); - if(value is IEnumerable objectListIteration) + foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) { - foreach(var iterationItem in objectListIteration.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(iterationItem); - } + writer.WriteStringValue(commonFileStoreItem); } - + writer.WriteEndArray(); - break; - case "lastmodifiedon": - var allowedVersionsForLastModifiedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("engineeringModelSetup"u8); + writer.WriteStringValue(engineeringModel.EngineeringModelSetup); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForLastModifiedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "logentry": - var allowedVersionsForLogEntry = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("genericNote"u8); - if(!allowedVersionsForLogEntry.Contains(requestedVersion)) + foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(genericNoteItem); } - writer.WriteStartArray("logEntry"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModel.Iid); + writer.WriteStartArray("iteration"u8); - if(value is IEnumerable objectListLogEntry) + foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) { - foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(logEntryItem); - } + writer.WriteStringValue(iterationItem); } - + writer.WriteEndArray(); - break; - case "modellingannotation": - var allowedVersionsForModellingAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); - if(!allowedVersionsForModellingAnnotation.Contains(requestedVersion)) + foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(logEntryItem); } + writer.WriteEndArray(); + writer.WriteStartArray("modellingAnnotation"u8); - if(value is IEnumerable objectListModellingAnnotation) + foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var modellingAnnotationItem in objectListModellingAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(modellingAnnotationItem); - } + writer.WriteStringValue(modellingAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModel.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModel.ThingPreference); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { @@ -417,25 +430,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "book": + if(!AllowedVersionsPerProperty["book"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + writer.WriteStartArray("book"u8); + + if(value is IEnumerable objectListBook) + { + foreach(var bookItem in objectListBook.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(bookItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -443,23 +466,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List + case "commonfilestore": + if(!AllowedVersionsPerProperty["commonFileStore"].Contains(requestedVersion)) { - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("commonFileStore"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListCommonFileStore) + { + foreach(var commonFileStoreItem in objectListCommonFileStore.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(commonFileStoreItem); + } + } + + writer.WriteEndArray(); + break; + case "engineeringmodelsetup": + if(!AllowedVersionsPerProperty["engineeringModelSetup"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("engineeringModelSetup"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -467,331 +502,231 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModel"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not EngineeringModel engineeringModel) - { - throw new ArgumentException("The thing shall be a EngineeringModel", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModel since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModel.ClassKind.ToString()); - writer.WriteStartArray("commonFileStore"u8); - - foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(commonFileStoreItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelSetup"u8); - writer.WriteStringValue(engineeringModel.EngineeringModelSetup); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModel.Iid); - writer.WriteStartArray("iteration"u8); - - foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(iterationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(logEntryItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModel.RevisionNumber); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.1.0"); - writer.WriteStartArray("book"u8); - - foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteOrderedItem(bookItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModel.ClassKind.ToString()); - writer.WriteStartArray("commonFileStore"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(commonFileStoreItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelSetup"u8); - writer.WriteStringValue(engineeringModel.EngineeringModelSetup); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "genericnote": + if(!AllowedVersionsPerProperty["genericNote"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("genericNote"u8); - foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGenericNote) { - writer.WriteStringValue(excludedPersonItem); + foreach(var genericNoteItem in objectListGenericNote.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(genericNoteItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("genericNote"u8); - - foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(genericNoteItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModel.Iid); - writer.WriteStartArray("iteration"u8); - - foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(iterationItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); - - foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(logEntryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("modellingAnnotation"u8); - - foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + break; + case "iteration": + if(!AllowedVersionsPerProperty["iteration"].Contains(requestedVersion)) { - writer.WriteStringValue(modellingAnnotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModel.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.2.0"); - writer.WriteStartArray("book"u8); + writer.WriteStartArray("iteration"u8); - foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListIteration) { - writer.WriteOrderedItem(bookItem); + foreach(var iterationItem in objectListIteration.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModel.ClassKind.ToString()); - writer.WriteStartArray("commonFileStore"u8); - - foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + break; + case "lastmodifiedon": + if(!AllowedVersionsPerProperty["lastModifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(commonFileStoreItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelSetup"u8); - writer.WriteStringValue(engineeringModel.EngineeringModelSetup); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("lastModifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("genericNote"u8); - - foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + break; + case "logentry": + if(!AllowedVersionsPerProperty["logEntry"].Contains(requestedVersion)) { - writer.WriteStringValue(genericNoteItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModel.Iid); - writer.WriteStartArray("iteration"u8); + writer.WriteStartArray("logEntry"u8); - foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListLogEntry) { - writer.WriteStringValue(iterationItem); + foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); - - foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + break; + case "modellingannotation": + if(!AllowedVersionsPerProperty["modellingAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(logEntryItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("modellingAnnotation"u8); - foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListModellingAnnotation) { - writer.WriteStringValue(modellingAnnotationItem); + foreach(var modellingAnnotationItem in objectListModellingAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modellingAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModel.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModel.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModel for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(engineeringModel.Actor.HasValue) - { - writer.WriteStringValue(engineeringModel.Actor.Value); - } - else + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("book"u8); - - foreach(var bookItem in engineeringModel.Book.OrderBy(x => x, this.OrderedItemComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteOrderedItem(bookItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModel.ClassKind.ToString()); - writer.WriteStartArray("commonFileStore"u8); - - foreach(var commonFileStoreItem in engineeringModel.CommonFileStore.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(commonFileStoreItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelSetup"u8); - writer.WriteStringValue(engineeringModel.EngineeringModelSetup); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModel.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModel.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("genericNote"u8); - - foreach(var genericNoteItem in engineeringModel.GenericNote.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(genericNoteItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModel.Iid); - writer.WriteStartArray("iteration"u8); - - foreach(var iterationItem in engineeringModel.Iteration.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(iterationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(engineeringModel.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); - - foreach(var logEntryItem in engineeringModel.LogEntry.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(logEntryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("modellingAnnotation"u8); - - foreach(var modellingAnnotationItem in engineeringModel.ModellingAnnotation.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(modellingAnnotationItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModel.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModel.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModel.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModel"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "book", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "commonFileStore", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "engineeringModelSetup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "genericNote", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iteration", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "lastModifiedOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "logEntry", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modellingAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs index a26486065..7ee57ff94 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EngineeringModelSetupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,543 +51,563 @@ namespace CDP4JsonSerializer public class EngineeringModelSetupSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not EngineeringModelSetup engineeringModelSetup) + { + throw new ArgumentException("The thing shall be a EngineeringModelSetup", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "activedomain": - var allowedVersionsForActiveDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelSetup since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActiveDomain.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelSetup for Version 1.0.0"); writer.WriteStartArray("activeDomain"u8); - if(value is IEnumerable objectListActiveDomain) + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var activeDomainItem in objectListActiveDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(activeDomainItem); - } + writer.WriteStringValue(activeDomainItem); } - + writer.WriteEndArray(); - break; - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(iterationSetupItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("participant"u8); - if(value is IEnumerable objectListAlias) + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(participantItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("requiredRdl"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requiredRdlItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); break; - case "defaultorganizationalparticipant": - var allowedVersionsForDefaultOrganizationalParticipant = new List - { - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelSetup for Version 1.1.0"); + writer.WriteStartArray("activeDomain"u8); - if(!allowedVersionsForDefaultOrganizationalParticipant.Contains(requestedVersion)) + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(activeDomainItem); } - writer.WritePropertyName("defaultOrganizationalParticipant"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(aliasItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List + writer.WriteEndArray(); + + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } + writer.WriteEndArray(); - break; - case "engineeringmodeliid": - var allowedVersionsForEngineeringModelIid = new List + + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(participantItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("requiredRdl"u8); - if(!allowedVersionsForEngineeringModelIid.Contains(requestedVersion)) + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requiredRdlItem); } - writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelSetup for Version 1.2.0"); + writer.WriteStartArray("activeDomain"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(activeDomainItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WritePropertyName("defaultOrganizationalParticipant"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) { - return; + writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); + + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(iterationSetupItem); } - break; - case "iterationsetup": - var allowedVersionsForIterationSetup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("organizationalParticipant"u8); - if(!allowedVersionsForIterationSetup.Contains(requestedVersion)) + foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(organizationalParticipantItem); } - writer.WriteStartArray("iterationSetup"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("participant"u8); - if(value is IEnumerable objectListIterationSetup) + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) { - foreach(var iterationSetupItem in objectListIterationSetup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(iterationSetupItem); - } + writer.WriteStringValue(participantItem); } - + writer.WriteEndArray(); - break; - case "kind": - var allowedVersionsForKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("requiredRdl"u8); - if(!allowedVersionsForKind.Contains(requestedVersion)) + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requiredRdlItem); } - writer.WritePropertyName("kind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) { - writer.WriteStringValue(((EngineeringModelKind)value).ToString()); + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelSetup.ThingPreference); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EngineeringModelSetup for Version 1.3.0"); + writer.WriteStartArray("activeDomain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(activeDomainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("actor"u8); + + if(engineeringModelSetup.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(engineeringModelSetup.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); + writer.WritePropertyName("defaultOrganizationalParticipant"u8); + + if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); } else { writer.WriteNullValue(); } - break; - case "organizationalparticipant": - var allowedVersionsForOrganizationalParticipant = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForOrganizationalParticipant.Contains(requestedVersion)) + foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("organizationalParticipant"u8); - - if(value is IEnumerable objectListOrganizationalParticipant) - { - foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(organizationalParticipantItem); - } - } - writer.WriteEndArray(); - break; - case "participant": - var allowedVersionsForParticipant = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("engineeringModelIid"u8); + writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForParticipant.Contains(requestedVersion)) + foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("participant"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListParticipant) + foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var participantItem in objectListParticipant.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(participantItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "requiredrdl": - var allowedVersionsForRequiredRdl = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("requiredRdl"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(engineeringModelSetup.Iid); + writer.WriteStartArray("iterationSetup"u8); - if(value is IEnumerable objectListRequiredRdl) + foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) { - foreach(var requiredRdlItem in objectListRequiredRdl.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(requiredRdlItem); - } + writer.WriteStringValue(iterationSetupItem); } - + writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("kind"u8); + writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(engineeringModelSetup.Name); + writer.WriteStartArray("organizationalParticipant"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(organizationalParticipantItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WriteStartArray("participant"u8); + + foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(participantItem); } - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("requiredRdl"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requiredRdlItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(engineeringModelSetup.ShortName); + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("studyPhase"u8); + writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(engineeringModelSetup.ThingPreference); break; - case "sourceengineeringmodelsetupiid": - var allowedVersionsForSourceEngineeringModelSetupIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForSourceEngineeringModelSetupIid.Contains(requestedVersion)) - { - return; + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "activedomain": + if(!AllowedVersionsPerProperty["activeDomain"].Contains(requestedVersion)) + { + return; } - writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + writer.WriteStartArray("activeDomain"u8); + + if(value is IEnumerable objectListActiveDomain) + { + foreach(var activeDomainItem in objectListActiveDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(activeDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); if(value != null) { @@ -598,25 +619,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "studyphase": - var allowedVersionsForStudyPhase = new List + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForStudyPhase.Contains(requestedVersion)) + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("studyPhase"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((StudyPhaseKind)value).ToString()); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -624,23 +655,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "defaultorganizationalparticipant": + if(!AllowedVersionsPerProperty["defaultOrganizationalParticipant"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("defaultOrganizationalParticipant"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -648,493 +673,364 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModelSetup"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not EngineeringModelSetup engineeringModelSetup) - { - throw new ArgumentException("The thing shall be a EngineeringModelSetup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EngineeringModelSetup since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.0.0"); - writer.WriteStartArray("activeDomain"u8); - - foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(activeDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("definition"u8); - foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(aliasItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "engineeringmodeliid": + if(!AllowedVersionsPerProperty["engineeringModelIid"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("engineeringModelIid"u8); - writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelSetup.Iid); - writer.WriteStartArray("iterationSetup"u8); - - foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(iterationSetupItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(engineeringModelSetup.Name); - writer.WriteStartArray("participant"u8); - - foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(participantItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("requiredRdl"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(requiredRdlItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(engineeringModelSetup.ShortName); - writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); - - if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) - { - writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); - } - else + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WritePropertyName("studyPhase"u8); - writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.1.0"); - writer.WriteStartArray("activeDomain"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(activeDomainItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelIid"u8); - writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelSetup.Iid); - writer.WriteStartArray("iterationSetup"u8); - - foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + break; + case "iterationsetup": + if(!AllowedVersionsPerProperty["iterationSetup"].Contains(requestedVersion)) { - writer.WriteStringValue(iterationSetupItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(engineeringModelSetup.Name); - writer.WriteStartArray("participant"u8); + writer.WriteStartArray("iterationSetup"u8); - foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListIterationSetup) { - writer.WriteStringValue(participantItem); + foreach(var iterationSetupItem in objectListIterationSetup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(iterationSetupItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("requiredRdl"u8); - - foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + break; + case "kind": + if(!AllowedVersionsPerProperty["kind"].Contains(requestedVersion)) { - writer.WriteStringValue(requiredRdlItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(engineeringModelSetup.ShortName); - writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); - - if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + writer.WritePropertyName("kind"u8); + + if(value != null) { - writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + writer.WriteStringValue(((EngineeringModelKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WritePropertyName("studyPhase"u8); - writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.2.0"); - writer.WriteStartArray("activeDomain"u8); - - foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(activeDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); - writer.WritePropertyName("defaultOrganizationalParticipant"u8); - - if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelIid"u8); - writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "organizationalparticipant": + if(!AllowedVersionsPerProperty["organizationalParticipant"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelSetup.Iid); - writer.WriteStartArray("iterationSetup"u8); + writer.WriteStartArray("organizationalParticipant"u8); - foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListOrganizationalParticipant) { - writer.WriteStringValue(iterationSetupItem); + foreach(var organizationalParticipantItem in objectListOrganizationalParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationalParticipantItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(engineeringModelSetup.Name); - writer.WriteStartArray("organizationalParticipant"u8); - - foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + break; + case "participant": + if(!AllowedVersionsPerProperty["participant"].Contains(requestedVersion)) { - writer.WriteStringValue(organizationalParticipantItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("participant"u8); - foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParticipant) { - writer.WriteStringValue(participantItem); + foreach(var participantItem in objectListParticipant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("requiredRdl"u8); - - foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + break; + case "requiredrdl": + if(!AllowedVersionsPerProperty["requiredRdl"].Contains(requestedVersion)) { - writer.WriteStringValue(requiredRdlItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(engineeringModelSetup.ShortName); - writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + writer.WriteStartArray("requiredRdl"u8); - if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) - { - writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); - } - else + if(value is IEnumerable objectListRequiredRdl) { - writer.WriteNullValue(); + foreach(var requiredRdlItem in objectListRequiredRdl.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requiredRdlItem); + } } - - writer.WritePropertyName("studyPhase"u8); - writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelSetup.ThingPreference); + + writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EngineeringModelSetup for Version 1.3.0"); - writer.WriteStartArray("activeDomain"u8); - - foreach(var activeDomainItem in engineeringModelSetup.ActiveDomain.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(activeDomainItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("actor"u8); - - if(engineeringModelSetup.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(engineeringModelSetup.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in engineeringModelSetup.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(engineeringModelSetup.ClassKind.ToString()); - writer.WritePropertyName("defaultOrganizationalParticipant"u8); - - if(engineeringModelSetup.DefaultOrganizationalParticipant.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(engineeringModelSetup.DefaultOrganizationalParticipant.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in engineeringModelSetup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("engineeringModelIid"u8); - writer.WriteStringValue(engineeringModelSetup.EngineeringModelIid); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in engineeringModelSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceengineeringmodelsetupiid": + if(!AllowedVersionsPerProperty["sourceEngineeringModelSetupIid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in engineeringModelSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in engineeringModelSetup.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(engineeringModelSetup.Iid); - writer.WriteStartArray("iterationSetup"u8); - - foreach(var iterationSetupItem in engineeringModelSetup.IterationSetup.OrderBy(x => x, this.GuidComparer)) + break; + case "studyphase": + if(!AllowedVersionsPerProperty["studyPhase"].Contains(requestedVersion)) { - writer.WriteStringValue(iterationSetupItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("kind"u8); - writer.WriteStringValue(engineeringModelSetup.Kind.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(engineeringModelSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(engineeringModelSetup.Name); - writer.WriteStartArray("organizationalParticipant"u8); - - foreach(var organizationalParticipantItem in engineeringModelSetup.OrganizationalParticipant.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("studyPhase"u8); + + if(value != null) { - writer.WriteStringValue(organizationalParticipantItem); + writer.WriteStringValue(((StudyPhaseKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WriteStartArray("participant"u8); - - foreach(var participantItem in engineeringModelSetup.Participant.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(participantItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("requiredRdl"u8); - - foreach(var requiredRdlItem in engineeringModelSetup.RequiredRdl.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(requiredRdlItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(engineeringModelSetup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(engineeringModelSetup.ShortName); - writer.WritePropertyName("sourceEngineeringModelSetupIid"u8); - - if(engineeringModelSetup.SourceEngineeringModelSetupIid.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(engineeringModelSetup.SourceEngineeringModelSetupIid.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("studyPhase"u8); - writer.WriteStringValue(engineeringModelSetup.StudyPhase.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(engineeringModelSetup.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the EngineeringModelSetup"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "activeDomain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultOrganizationalParticipant", new []{ "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "engineeringModelIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iterationSetup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "kind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "organizationalParticipant", new []{ "1.2.0", "1.3.0" }}, + { "participant", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "requiredRdl", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceEngineeringModelSetupIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "studyPhase", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs index 17bfcb6e1..64c281224 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,369 +51,393 @@ namespace CDP4JsonSerializer public class EnumerationParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not EnumerationParameterType enumerationParameterType) + { + throw new ArgumentException("The thing shall be a EnumerationParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of EnumerationParameterType since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing EnumerationParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListAlias) + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "allowmultiselect": - var allowedVersionsForAllowMultiSelect = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAllowMultiSelect.Contains(requestedVersion)) + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing EnumerationParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteOrderedItem(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing EnumerationParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationParameterType.ThingPreference); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(valueDefinitionItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing EnumerationParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(enumerationParameterType.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(enumerationParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("allowMultiSelect"u8); + writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "name": - var allowedVersionsForName = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(enumerationParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(enumerationParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(enumerationParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(enumerationParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(enumerationParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(enumerationParameterType.ThingPreference); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -420,25 +445,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "allowmultiselect": + if(!AllowedVersionsPerProperty["allowMultiSelect"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("allowMultiSelect"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -446,25 +481,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "symbol": - var allowedVersionsForSymbol = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,397 +517,269 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); break; - case "valuedefinition": - var allowedVersionsForValueDefinition = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("valueDefinition"u8); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListValueDefinition) + if(value is IEnumerable objectListHyperLink) { - foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.OrderedItemComparer)) + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteOrderedItem(valueDefinitionItem); + writer.WriteStringValue(hyperLinkItem); } } writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationParameterType"); - } - } + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not EnumerationParameterType enumerationParameterType) - { - throw new ArgumentException("The thing shall be a EnumerationParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of EnumerationParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("allowMultiSelect"u8); - writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(enumerationParameterType.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(enumerationParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(enumerationParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(enumerationParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(enumerationParameterType.Symbol); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(valueDefinitionItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("allowMultiSelect"u8); - writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(enumerationParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(enumerationParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(enumerationParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(enumerationParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(enumerationParameterType.Symbol); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(valueDefinitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("allowMultiSelect"u8); - writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(enumerationParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(enumerationParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(enumerationParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(enumerationParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(enumerationParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(enumerationParameterType.ThingPreference); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteOrderedItem(valueDefinitionItem); + return; } - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(enumerationParameterType.Actor.HasValue) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(enumerationParameterType.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in enumerationParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("allowMultiSelect"u8); - writer.WriteBooleanValue(enumerationParameterType.AllowMultiSelect); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in enumerationParameterType.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(enumerationParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in enumerationParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in enumerationParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in enumerationParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in enumerationParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "valuedefinition": + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(enumerationParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(enumerationParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(enumerationParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(enumerationParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(enumerationParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(enumerationParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(enumerationParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(enumerationParameterType.ThingPreference); writer.WriteStartArray("valueDefinition"u8); - foreach(var valueDefinitionItem in enumerationParameterType.ValueDefinition.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListValueDefinition) { - writer.WriteOrderedItem(valueDefinitionItem); + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(valueDefinitionItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "allowMultiSelect", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs index 03c22ebbd..ccb846988 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/EnumerationValueDefinitionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,354 +50,6 @@ namespace CDP4JsonSerializer /// public class EnumerationValueDefinitionSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("alias"u8); - - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationValueDefinition"); - } - } - /// /// Serializes a into an /// @@ -423,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing EnumerationValueDefinition for Version 1.0.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -432,6 +85,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -442,6 +96,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -450,6 +105,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(enumerationValueDefinition.Iid); writer.WritePropertyName("name"u8); @@ -460,7 +116,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(enumerationValueDefinition.ShortName); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing EnumerationValueDefinition for Version 1.1.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -469,6 +125,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -479,6 +136,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -487,6 +145,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -495,6 +154,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -503,6 +163,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(enumerationValueDefinition.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -515,7 +176,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(enumerationValueDefinition.ShortName); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing EnumerationValueDefinition for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in enumerationValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -524,6 +185,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -534,6 +196,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -542,6 +205,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -550,6 +214,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -558,6 +223,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(enumerationValueDefinition.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -572,7 +238,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(enumerationValueDefinition.ThingPreference); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing EnumerationValueDefinition for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing EnumerationValueDefinition for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(enumerationValueDefinition.Actor.HasValue) @@ -592,6 +258,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(enumerationValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -602,6 +269,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in enumerationValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -610,6 +278,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in enumerationValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -618,6 +287,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in enumerationValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -626,6 +296,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(enumerationValueDefinition.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -645,6 +316,279 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the EnumerationValueDefinition"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs index 53ec45716..7efaec894 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ExclusiveOrExpressionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,185 @@ namespace CDP4JsonSerializer /// public class ExclusiveOrExpressionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ExclusiveOrExpression exclusiveOrExpression) + { + throw new ArgumentException("The thing shall be a ExclusiveOrExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ExclusiveOrExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ExclusiveOrExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ExclusiveOrExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ExclusiveOrExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(exclusiveOrExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ExclusiveOrExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(exclusiveOrExpression.Actor.HasValue) + { + writer.WriteStringValue(exclusiveOrExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(exclusiveOrExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(exclusiveOrExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +236,7 @@ public class ExclusiveOrExpressionSerializer : BaseThingSerializer, IThingSerial /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +244,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +298,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +316,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +334,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +352,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +370,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "term": - var allowedVersionsForTerm = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTerm.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["term"].Contains(requestedVersion)) { return; } @@ -265,13 +388,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -294,173 +411,20 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ExclusiveOrExpression exclusiveOrExpression) - { - throw new ArgumentException("The thing shall be a ExclusiveOrExpression", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ExclusiveOrExpression since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(exclusiveOrExpression.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(exclusiveOrExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(exclusiveOrExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(exclusiveOrExpression.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ExclusiveOrExpression for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(exclusiveOrExpression.Actor.HasValue) - { - writer.WriteStringValue(exclusiveOrExpression.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(exclusiveOrExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in exclusiveOrExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in exclusiveOrExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(exclusiveOrExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(exclusiveOrExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(exclusiveOrExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in exclusiveOrExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(exclusiveOrExpression.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "term", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs index 90f4cc197..111625268 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ExternalIdentifierMapSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,269 @@ namespace CDP4JsonSerializer /// public class ExternalIdentifierMapSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ExternalIdentifierMap externalIdentifierMap) + { + throw new ArgumentException("The thing shall be a ExternalIdentifierMap", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ExternalIdentifierMap since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ExternalIdentifierMap for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ExternalIdentifierMap for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ExternalIdentifierMap for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(externalIdentifierMap.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ExternalIdentifierMap for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(externalIdentifierMap.Actor.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); + writer.WriteStartArray("correspondence"u8); + + foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(correspondenceItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalFormat"u8); + + if(externalIdentifierMap.ExternalFormat.HasValue) + { + writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("externalModelName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalModelName); + writer.WritePropertyName("externalToolName"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolName); + writer.WritePropertyName("externalToolVersion"u8); + writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(externalIdentifierMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(externalIdentifierMap.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(externalIdentifierMap.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(externalIdentifierMap.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +320,7 @@ public class ExternalIdentifierMapSerializer : BaseThingSerializer, IThingSerial /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +328,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +346,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +364,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "correspondence": - var allowedVersionsForCorrespondence = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCorrespondence.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["correspondence"].Contains(requestedVersion)) { return; } @@ -138,14 +382,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +400,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +418,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "externalformat": - var allowedVersionsForExternalFormat = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExternalFormat.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["externalFormat"].Contains(requestedVersion)) { return; } @@ -214,15 +436,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "externalmodelname": - var allowedVersionsForExternalModelName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExternalModelName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["externalModelName"].Contains(requestedVersion)) { return; } @@ -240,15 +454,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "externaltoolname": - var allowedVersionsForExternalToolName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExternalToolName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["externalToolName"].Contains(requestedVersion)) { return; } @@ -266,15 +472,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "externaltoolversion": - var allowedVersionsForExternalToolVersion = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExternalToolVersion.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["externalToolVersion"].Contains(requestedVersion)) { return; } @@ -291,16 +489,8 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -318,14 +508,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -343,15 +526,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -369,15 +544,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -395,15 +562,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -421,13 +580,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -450,257 +603,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ExternalIdentifierMap externalIdentifierMap) - { - throw new ArgumentException("The thing shall be a ExternalIdentifierMap", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ExternalIdentifierMap since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); - writer.WriteStartArray("correspondence"u8); - - foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(correspondenceItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalFormat"u8); - - if(externalIdentifierMap.ExternalFormat.HasValue) - { - writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("externalModelName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalModelName); - writer.WritePropertyName("externalToolName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolName); - writer.WritePropertyName("externalToolVersion"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(externalIdentifierMap.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(externalIdentifierMap.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(externalIdentifierMap.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); - writer.WriteStartArray("correspondence"u8); - - foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(correspondenceItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalFormat"u8); - - if(externalIdentifierMap.ExternalFormat.HasValue) - { - writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("externalModelName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalModelName); - writer.WritePropertyName("externalToolName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolName); - writer.WritePropertyName("externalToolVersion"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(externalIdentifierMap.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(externalIdentifierMap.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(externalIdentifierMap.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); - writer.WriteStartArray("correspondence"u8); - - foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(correspondenceItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalFormat"u8); - - if(externalIdentifierMap.ExternalFormat.HasValue) - { - writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("externalModelName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalModelName); - writer.WritePropertyName("externalToolName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolName); - writer.WritePropertyName("externalToolVersion"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(externalIdentifierMap.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(externalIdentifierMap.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(externalIdentifierMap.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(externalIdentifierMap.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ExternalIdentifierMap for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(externalIdentifierMap.Actor.HasValue) - { - writer.WriteStringValue(externalIdentifierMap.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(externalIdentifierMap.ClassKind.ToString()); - writer.WriteStartArray("correspondence"u8); - - foreach(var correspondenceItem in externalIdentifierMap.Correspondence.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(correspondenceItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in externalIdentifierMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in externalIdentifierMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalFormat"u8); - - if(externalIdentifierMap.ExternalFormat.HasValue) - { - writer.WriteStringValue(externalIdentifierMap.ExternalFormat.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("externalModelName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalModelName); - writer.WritePropertyName("externalToolName"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolName); - writer.WritePropertyName("externalToolVersion"u8); - writer.WriteStringValue(externalIdentifierMap.ExternalToolVersion); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(externalIdentifierMap.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(externalIdentifierMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(externalIdentifierMap.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(externalIdentifierMap.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(externalIdentifierMap.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(externalIdentifierMap.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "correspondence", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "externalFormat", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "externalModelName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "externalToolName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "externalToolVersion", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs index 3fe0cb979..3685cd366 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileRevisionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,261 @@ namespace CDP4JsonSerializer /// public class FileRevisionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not FileRevision fileRevision) + { + throw new ArgumentException("The thing shall be a FileRevision", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of FileRevision since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing FileRevision for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing FileRevision for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing FileRevision for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileRevision.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing FileRevision for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(fileRevision.Actor.HasValue) + { + writer.WriteStringValue(fileRevision.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileRevision.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(fileRevision.ContainingFolder.HasValue) + { + writer.WriteStringValue(fileRevision.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("contentHash"u8); + writer.WriteStringValue(fileRevision.ContentHash); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(fileRevision.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(fileTypeItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileRevision.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileRevision.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileRevision.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileRevision.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +312,7 @@ public class FileRevisionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +320,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +338,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +356,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "containingfolder": - var allowedVersionsForContainingFolder = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContainingFolder.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["containingFolder"].Contains(requestedVersion)) { return; } @@ -138,15 +374,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "contenthash": - var allowedVersionsForContentHash = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContentHash.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["contentHash"].Contains(requestedVersion)) { return; } @@ -163,16 +391,8 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -190,15 +410,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "creator": - var allowedVersionsForCreator = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreator.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["creator"].Contains(requestedVersion)) { return; } @@ -216,14 +428,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -241,14 +446,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -266,15 +464,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "filetype": - var allowedVersionsForFileType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFileType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["fileType"].Contains(requestedVersion)) { return; } @@ -292,15 +482,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -318,14 +500,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -343,15 +518,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -369,15 +536,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -395,13 +554,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -424,249 +577,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not FileRevision fileRevision) - { - throw new ArgumentException("The thing shall be a FileRevision", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of FileRevision since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileRevision.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(fileRevision.ContainingFolder.HasValue) - { - writer.WriteStringValue(fileRevision.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("contentHash"u8); - writer.WriteStringValue(fileRevision.ContentHash); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(fileRevision.Creator); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(fileTypeItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileRevision.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileRevision.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileRevision.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileRevision.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(fileRevision.ContainingFolder.HasValue) - { - writer.WriteStringValue(fileRevision.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("contentHash"u8); - writer.WriteStringValue(fileRevision.ContentHash); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(fileRevision.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(fileTypeItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileRevision.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileRevision.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileRevision.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileRevision.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(fileRevision.ContainingFolder.HasValue) - { - writer.WriteStringValue(fileRevision.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("contentHash"u8); - writer.WriteStringValue(fileRevision.ContentHash); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(fileRevision.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(fileTypeItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileRevision.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileRevision.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileRevision.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(fileRevision.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing FileRevision for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(fileRevision.Actor.HasValue) - { - writer.WriteStringValue(fileRevision.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileRevision.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(fileRevision.ContainingFolder.HasValue) - { - writer.WriteStringValue(fileRevision.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("contentHash"u8); - writer.WriteStringValue(fileRevision.ContentHash); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(fileRevision.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(fileRevision.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileRevision.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileRevision.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in fileRevision.FileType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(fileTypeItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileRevision.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileRevision.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileRevision.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileRevision.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(fileRevision.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containingFolder", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "contentHash", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "creator", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fileType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs index 402554d07..0de93fab2 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,328 +50,6 @@ namespace CDP4JsonSerializer /// public class FileSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("category"u8); - - if(value is IEnumerable objectListCategory) - { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "filerevision": - var allowedVersionsForFileRevision = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFileRevision.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("fileRevision"u8); - - if(value is IEnumerable objectListFileRevision) - { - foreach(var fileRevisionItem in objectListFileRevision.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileRevisionItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "lockedby": - var allowedVersionsForLockedBy = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLockedBy.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("lockedBy"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("owner"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the File"); - } - } - /// /// Serializes a into an /// @@ -397,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing File for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing File for Version 1.0.0"); writer.WriteStartArray("category"u8); foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) @@ -406,6 +85,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(file.ClassKind.ToString()); writer.WriteStartArray("fileRevision"u8); @@ -416,6 +96,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(file.Iid); writer.WritePropertyName("lockedBy"u8); @@ -435,7 +116,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(file.RevisionNumber); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing File for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing File for Version 1.1.0"); writer.WriteStartArray("category"u8); foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) @@ -444,6 +125,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(file.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -454,6 +136,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -462,6 +145,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) @@ -470,6 +154,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(file.Iid); writer.WritePropertyName("lockedBy"u8); @@ -491,7 +176,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(file.RevisionNumber); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing File for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing File for Version 1.2.0"); writer.WriteStartArray("category"u8); foreach(var categoryItem in file.Category.OrderBy(x => x, this.GuidComparer)) @@ -500,6 +185,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(file.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -510,6 +196,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -518,6 +205,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) @@ -526,6 +214,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(file.Iid); writer.WritePropertyName("lockedBy"u8); @@ -549,7 +238,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(file.ThingPreference); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing File for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing File for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(file.Actor.HasValue) @@ -569,6 +258,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(file.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -579,6 +269,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in file.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -587,6 +278,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("fileRevision"u8); foreach(var fileRevisionItem in file.FileRevision.OrderBy(x => x, this.GuidComparer)) @@ -595,6 +287,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(file.Iid); writer.WritePropertyName("lockedBy"u8); @@ -623,6 +316,260 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "filerevision": + if(!AllowedVersionsPerProperty["fileRevision"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("fileRevision"u8); + + if(value is IEnumerable objectListFileRevision) + { + foreach(var fileRevisionItem in objectListFileRevision.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileRevisionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "lockedby": + if(!AllowedVersionsPerProperty["lockedBy"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("lockedBy"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the File"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fileRevision", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "lockedBy", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs index 71b13359f..abb0ef315 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FileTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,292 +51,349 @@ namespace CDP4JsonSerializer public class FileTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not FileType fileType) + { + throw new ArgumentException("The thing shall be a FileType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of FileType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing FileType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing FileType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing FileType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "extension": - var allowedVersionsForExtension = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExtension.Contains(requestedVersion)) + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("extension"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing FileType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(fileType.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(fileType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(fileType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("extension"u8); + writer.WriteStringValue(fileType.Extension); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(fileType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(fileType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(fileType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(fileType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(fileType.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(fileType.ThingPreference); break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("isDeprecated"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue((Guid)value); } else { @@ -343,50 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -394,71 +455,67 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNumberValue((int)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) { - return; + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - - writer.WritePropertyName("shortName"u8); - if(value != null) + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue((string)value); + return; } - else + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteNullValue(); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "extension": + if(!AllowedVersionsPerProperty["extension"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("extension"u8); if(value != null) { @@ -470,307 +527,177 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the FileType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not FileType fileType) - { - throw new ArgumentException("The thing shall be a FileType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of FileType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("extension"u8); - writer.WriteStringValue(fileType.Extension); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(fileType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(fileType.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("extension"u8); - writer.WriteStringValue(fileType.Extension); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(fileType.IsDeprecated); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(fileType.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("extension"u8); - writer.WriteStringValue(fileType.Extension); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(fileType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileType.Name); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(fileType.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(fileType.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing FileType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(fileType.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(fileType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in fileType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in fileType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(fileType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in fileType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in fileType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in fileType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("extension"u8); - writer.WriteStringValue(fileType.Extension); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in fileType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(fileType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(fileType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(fileType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(fileType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(fileType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(fileType.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(fileType.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the FileType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "extension", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs index fa69502d8..084799a73 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/FolderSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,225 @@ namespace CDP4JsonSerializer /// public class FolderSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Folder folder) + { + throw new ArgumentException("The thing shall be a Folder", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Folder since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Folder for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Folder for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Folder for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(folder.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Folder for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(folder.Actor.HasValue) + { + writer.WriteStringValue(folder.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(folder.ClassKind.ToString()); + writer.WritePropertyName("containingFolder"u8); + + if(folder.ContainingFolder.HasValue) + { + writer.WriteStringValue(folder.ContainingFolder.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("creator"u8); + writer.WriteStringValue(folder.Creator); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(folder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(folder.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(folder.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(folder.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(folder.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +276,7 @@ public class FolderSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +284,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +302,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +320,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "containingfolder": - var allowedVersionsForContainingFolder = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContainingFolder.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["containingFolder"].Contains(requestedVersion)) { return; } @@ -138,15 +338,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -164,15 +356,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "creator": - var allowedVersionsForCreator = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreator.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["creator"].Contains(requestedVersion)) { return; } @@ -190,14 +374,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -215,14 +392,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -240,15 +410,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -266,14 +428,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -291,15 +446,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -317,15 +464,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -343,15 +482,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -369,13 +500,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -398,217 +523,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Folder folder) - { - throw new ArgumentException("The thing shall be a Folder", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Folder since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(folder.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(folder.ContainingFolder.HasValue) - { - writer.WriteStringValue(folder.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(folder.Creator); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(folder.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(folder.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(folder.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(folder.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(folder.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(folder.ContainingFolder.HasValue) - { - writer.WriteStringValue(folder.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(folder.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(folder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(folder.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(folder.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(folder.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(folder.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(folder.ContainingFolder.HasValue) - { - writer.WriteStringValue(folder.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(folder.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(folder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(folder.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(folder.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(folder.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(folder.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Folder for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(folder.Actor.HasValue) - { - writer.WriteStringValue(folder.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(folder.ClassKind.ToString()); - writer.WritePropertyName("containingFolder"u8); - - if(folder.ContainingFolder.HasValue) - { - writer.WriteStringValue(folder.ContainingFolder.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(folder.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("creator"u8); - writer.WriteStringValue(folder.Creator); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in folder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in folder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(folder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(folder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(folder.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(folder.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(folder.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(folder.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containingFolder", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "creator", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs index b6bdf9a64..8574105e2 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/GlossarySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,377 @@ namespace CDP4JsonSerializer public class GlossarySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not Glossary glossary) + { + throw new ArgumentException("The thing shall be a Glossary", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of Glossary since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Glossary for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); - if(value is IEnumerable objectListAlias) + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(termItem); } - + writer.WriteEndArray(); + break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Glossary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); - if(value is IEnumerable objectListDefinition) + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(termItem); } - + writer.WriteEndArray(); + break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Glossary for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(termItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(glossary.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Glossary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(glossary.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(glossary.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(glossary.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(glossary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(glossary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(glossary.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(glossary.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(glossary.ShortName); + writer.WriteStartArray("term"u8); + + foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(termItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(glossary.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,75 +429,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "term": - var allowedVersionsForTerm = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTerm.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("term"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListTerm) + if(value is IEnumerable objectListCategory) { - foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(termItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -470,331 +483,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Glossary"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Glossary glossary) - { - throw new ArgumentException("The thing shall be a Glossary", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Glossary since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(glossary.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(glossary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(glossary.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(glossary.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(glossary.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(glossary.ShortName); - writer.WriteStartArray("term"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(termItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(glossary.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(excludedDomainItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(glossary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(glossary.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(glossary.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(glossary.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(glossary.ShortName); - writer.WriteStartArray("term"u8); - - foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(termItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(glossary.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(glossary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(glossary.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(glossary.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(glossary.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(glossary.ShortName); - writer.WriteStartArray("term"u8); - - foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(termItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(glossary.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Glossary for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(glossary.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(glossary.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in glossary.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in glossary.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(glossary.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in glossary.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in glossary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "term": + if(!AllowedVersionsPerProperty["term"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("term"u8); - foreach(var excludedPersonItem in glossary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListTerm) { - writer.WriteStringValue(excludedPersonItem); + foreach(var termItem in objectListTerm.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in glossary.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(glossary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(glossary.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(glossary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(glossary.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(glossary.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(glossary.ShortName); - writer.WriteStartArray("term"u8); - - foreach(var termItem in glossary.Term.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(termItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(glossary.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Glossary"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "term", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs index 6d418939f..0fa9e943c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/GoalSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,260 @@ namespace CDP4JsonSerializer /// public class GoalSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Goal goal) + { + throw new ArgumentException("The thing shall be a Goal", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Goal since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Goal for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Goal for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(goal.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Goal for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(goal.Actor.HasValue) + { + writer.WriteStringValue(goal.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(goal.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(goal.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(goal.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(goal.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(goal.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(goal.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +311,7 @@ public class GoalSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "alias": - var allowedVersionsForAlias = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } @@ -111,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -136,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -161,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "definition": - var allowedVersionsForDefinition = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } @@ -186,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } @@ -261,14 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +481,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +499,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -336,14 +517,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,14 +535,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +553,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,240 +576,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Goal goal) - { - throw new ArgumentException("The thing shall be a Goal", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Goal since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(goal.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(goal.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(goal.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(goal.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(goal.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(goal.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(goal.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(goal.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(goal.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(goal.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(goal.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Goal for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(goal.Actor.HasValue) - { - writer.WriteStringValue(goal.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in goal.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in goal.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(goal.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in goal.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in goal.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in goal.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in goal.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(goal.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(goal.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(goal.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(goal.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(goal.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(goal.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs index 13174fe29..d8d7d1034 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/HyperLinkSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class HyperLinkSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not HyperLink hyperLink) + { + throw new ArgumentException("The thing shall be a HyperLink", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of HyperLink since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing HyperLink for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing HyperLink for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing HyperLink for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(hyperLink.ThingPreference); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing HyperLink for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(hyperLink.Actor.HasValue) + { + writer.WriteStringValue(hyperLink.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(hyperLink.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(hyperLink.Content); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(hyperLink.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(hyperLink.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(hyperLink.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(hyperLink.ThingPreference); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(hyperLink.Uri); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class HyperLinkSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -138,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -240,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -315,15 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "uri": - var allowedVersionsForUri = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUri.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["uri"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not HyperLink hyperLink) - { - throw new ArgumentException("The thing shall be a HyperLink", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of HyperLink since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(hyperLink.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(hyperLink.Content); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(hyperLink.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(hyperLink.LanguageCode); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(hyperLink.RevisionNumber); - writer.WritePropertyName("uri"u8); - writer.WriteStringValue(hyperLink.Uri); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(hyperLink.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(hyperLink.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(hyperLink.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(hyperLink.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(hyperLink.RevisionNumber); - writer.WritePropertyName("uri"u8); - writer.WriteStringValue(hyperLink.Uri); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(hyperLink.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(hyperLink.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(hyperLink.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(hyperLink.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(hyperLink.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(hyperLink.ThingPreference); - writer.WritePropertyName("uri"u8); - writer.WriteStringValue(hyperLink.Uri); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing HyperLink for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(hyperLink.Actor.HasValue) - { - writer.WriteStringValue(hyperLink.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(hyperLink.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(hyperLink.Content); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in hyperLink.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in hyperLink.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(hyperLink.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(hyperLink.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(hyperLink.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(hyperLink.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(hyperLink.ThingPreference); - writer.WritePropertyName("uri"u8); - writer.WriteStringValue(hyperLink.Uri); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "uri", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs index e5921d733..2c602e0b1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IdCorrespondenceSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class IdCorrespondenceSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not IdCorrespondence idCorrespondence) + { + throw new ArgumentException("The thing shall be a IdCorrespondence", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of IdCorrespondence since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing IdCorrespondence for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing IdCorrespondence for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing IdCorrespondence for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(idCorrespondence.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing IdCorrespondence for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(idCorrespondence.Actor.HasValue) + { + writer.WriteStringValue(idCorrespondence.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("externalId"u8); + writer.WriteStringValue(idCorrespondence.ExternalId); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(idCorrespondence.Iid); + writer.WritePropertyName("internalThing"u8); + writer.WriteStringValue(idCorrespondence.InternalThing); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(idCorrespondence.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(idCorrespondence.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class IdCorrespondenceSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "externalid": - var allowedVersionsForExternalId = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExternalId.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["externalId"].Contains(requestedVersion)) { return; } @@ -188,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "internalthing": - var allowedVersionsForInternalThing = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForInternalThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["internalThing"].Contains(requestedVersion)) { return; } @@ -240,14 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not IdCorrespondence idCorrespondence) - { - throw new ArgumentException("The thing shall be a IdCorrespondence", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of IdCorrespondence since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); - writer.WritePropertyName("externalId"u8); - writer.WriteStringValue(idCorrespondence.ExternalId); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(idCorrespondence.Iid); - writer.WritePropertyName("internalThing"u8); - writer.WriteStringValue(idCorrespondence.InternalThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(idCorrespondence.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalId"u8); - writer.WriteStringValue(idCorrespondence.ExternalId); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(idCorrespondence.Iid); - writer.WritePropertyName("internalThing"u8); - writer.WriteStringValue(idCorrespondence.InternalThing); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(idCorrespondence.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalId"u8); - writer.WriteStringValue(idCorrespondence.ExternalId); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(idCorrespondence.Iid); - writer.WritePropertyName("internalThing"u8); - writer.WriteStringValue(idCorrespondence.InternalThing); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(idCorrespondence.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(idCorrespondence.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing IdCorrespondence for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(idCorrespondence.Actor.HasValue) - { - writer.WriteStringValue(idCorrespondence.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(idCorrespondence.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in idCorrespondence.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in idCorrespondence.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("externalId"u8); - writer.WriteStringValue(idCorrespondence.ExternalId); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(idCorrespondence.Iid); - writer.WritePropertyName("internalThing"u8); - writer.WriteStringValue(idCorrespondence.InternalThing); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(idCorrespondence.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(idCorrespondence.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(idCorrespondence.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "externalId", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "internalThing", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs index ef20fd8f1..0ba05cad9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IndependentParameterTypeAssignmentSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,137 @@ namespace CDP4JsonSerializer /// public class IndependentParameterTypeAssignmentSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not IndependentParameterTypeAssignment independentParameterTypeAssignment) + { + throw new ArgumentException("The thing shall be a IndependentParameterTypeAssignment", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of IndependentParameterTypeAssignment since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing IndependentParameterTypeAssignment for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(independentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(independentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing IndependentParameterTypeAssignment for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(independentParameterTypeAssignment.Actor.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(independentParameterTypeAssignment.Iid); + writer.WritePropertyName("measurementScale"u8); + + if(independentParameterTypeAssignment.MeasurementScale.HasValue) + { + writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +188,7 @@ public class IndependentParameterTypeAssignmentSerializer : BaseThingSerializer, /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +196,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,13 +214,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -110,14 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -135,14 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -160,13 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -184,13 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "measurementscale": - var allowedVersionsForMeasurementScale = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMeasurementScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["measurementScale"].Contains(requestedVersion)) { return; } @@ -208,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -233,13 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -257,13 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -281,13 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -310,131 +381,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not IndependentParameterTypeAssignment independentParameterTypeAssignment) - { - throw new ArgumentException("The thing shall be a IndependentParameterTypeAssignment", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.2.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of IndependentParameterTypeAssignment since Version is below 1.2.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing IndependentParameterTypeAssignment for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(independentParameterTypeAssignment.Iid); - writer.WritePropertyName("measurementScale"u8); - - if(independentParameterTypeAssignment.MeasurementScale.HasValue) - { - writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing IndependentParameterTypeAssignment for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(independentParameterTypeAssignment.Actor.HasValue) - { - writer.WriteStringValue(independentParameterTypeAssignment.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in independentParameterTypeAssignment.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in independentParameterTypeAssignment.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(independentParameterTypeAssignment.Iid); - writer.WritePropertyName("measurementScale"u8); - - if(independentParameterTypeAssignment.MeasurementScale.HasValue) - { - writer.WriteStringValue(independentParameterTypeAssignment.MeasurementScale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(independentParameterTypeAssignment.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(independentParameterTypeAssignment.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.2.0", "1.3.0" }}, + { "measurementScale", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs index 3dfd5bc22..6fa8d528c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IntervalScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,370 +51,441 @@ namespace CDP4JsonSerializer public class IntervalScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not IntervalScale intervalScale) + { + throw new ArgumentException("The thing shall be a IntervalScale", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of IntervalScale since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing IntervalScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing IntervalScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing IntervalScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(mappingToReferenceScaleItem); } - break; - case "ismaximuminclusive": - var allowedVersionsForIsMaximumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(intervalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing IntervalScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(intervalScale.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(intervalScale.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isminimuminclusive": - var allowedVersionsForIsMinimumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(intervalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "mappingtoreferencescale": - var allowedVersionsForMappingToReferenceScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("mappingToReferenceScale"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListMappingToReferenceScale) + foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "maximumpermissiblevalue": - var allowedVersionsForMaximumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(intervalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(intervalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(mappingToReferenceScaleItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(intervalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(intervalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(intervalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(intervalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(intervalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(intervalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(intervalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(intervalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(intervalScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "minimumpermissiblevalue": - var allowedVersionsForMinimumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -421,50 +493,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,103 +529,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "negativevalueconnotation": - var allowedVersionsForNegativeValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("negativeValueConnotation"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "numberset": - var allowedVersionsForNumberSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) { - return; + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - - writer.WritePropertyName("numberSet"u8); - if(value != null) - { - writer.WriteStringValue(((NumberSetKind)value).ToString()); - } - else + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "positivevalueconnotation": - var allowedVersionsForPositiveValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) { - return; + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - - writer.WritePropertyName("positiveValueConnotation"u8); - if(value != null) + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue((string)value); + return; } - else + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) { - writer.WriteNullValue(); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + + writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -576,25 +619,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -602,23 +637,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "ismaximuminclusive": + if(!AllowedVersionsPerProperty["isMaximumInclusive"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("isMaximumInclusive"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -626,25 +655,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + case "isminimuminclusive": + if(!AllowedVersionsPerProperty["isMinimumInclusive"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("unit"u8); + writer.WritePropertyName("isMinimumInclusive"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteBooleanValue((bool)value); } else { @@ -652,421 +673,275 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "valuedefinition": - var allowedVersionsForValueDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + case "mappingtoreferencescale": + if(!AllowedVersionsPerProperty["mappingToReferenceScale"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("valueDefinition"u8); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListValueDefinition) + if(value is IEnumerable objectListMappingToReferenceScale) { - foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue(mappingToReferenceScaleItem); } } writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the IntervalScale"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not IntervalScale intervalScale) - { - throw new ArgumentException("The thing shall be a IntervalScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of IntervalScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "maximumpermissiblevalue": + if(!AllowedVersionsPerProperty["maximumPermissibleValue"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(intervalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(intervalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(intervalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "minimumpermissiblevalue": + if(!AllowedVersionsPerProperty["minimumPermissibleValue"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MaximumPermissibleValue); writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MinimumPermissibleValue); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(intervalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(intervalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(intervalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(intervalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(intervalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(intervalScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(intervalScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(intervalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(intervalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(intervalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "negativevalueconnotation": + if(!AllowedVersionsPerProperty["negativeValueConnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(intervalScale.Name); writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(intervalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(intervalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(intervalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(intervalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(intervalScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(intervalScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "numberset": + if(!AllowedVersionsPerProperty["numberSet"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(intervalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("numberSet"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((NumberSetKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "positivevalueconnotation": + if(!AllowedVersionsPerProperty["positiveValueConnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(intervalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(intervalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(intervalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(intervalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(intervalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(intervalScale.PositiveValueConnotation); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(intervalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(intervalScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(intervalScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(intervalScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing IntervalScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(intervalScale.Actor.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(intervalScale.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in intervalScale.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(intervalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in intervalScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in intervalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in intervalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "unit": + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in intervalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("unit"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(intervalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(intervalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(intervalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in intervalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "valuedefinition": + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(intervalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(intervalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(intervalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(intervalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(intervalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(intervalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(intervalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(intervalScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(intervalScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(intervalScale.Unit); writer.WriteStartArray("valueDefinition"u8); - foreach(var valueDefinitionItem in intervalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListValueDefinition) { - writer.WriteStringValue(valueDefinitionItem); + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the IntervalScale"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMaximumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMinimumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "mappingToReferenceScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maximumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minimumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "negativeValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "numberSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "positiveValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs index 618c3355b..09ac4f3a3 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,789 +51,613 @@ namespace CDP4JsonSerializer public class IterationSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not Iteration iteration) + { + throw new ArgumentException("The thing shall be a Iteration", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of Iteration since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Iteration for Version 1.0.0"); + writer.WriteStartArray("actualFiniteStateList"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(actualFiniteStateListItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); + + if(iteration.DefaultOption.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(iteration.DefaultOption.Value); } else { writer.WriteNullValue(); } - break; - case "actualfinitestatelist": - var allowedVersionsForActualFiniteStateList = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("domainFileStore"u8); - if(!allowedVersionsForActualFiniteStateList.Contains(requestedVersion)) + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainFileStoreItem); } - writer.WriteStartArray("actualFiniteStateList"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("element"u8); - if(value is IEnumerable objectListActualFiniteStateList) + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) { - foreach(var actualFiniteStateListItem in objectListActualFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(actualFiniteStateListItem); - } + writer.WriteStringValue(elementItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("externalIdentifierMap"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(externalIdentifierMapItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WriteStartArray("option"u8); + + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(optionItem); } - break; - case "defaultoption": - var allowedVersionsForDefaultOption = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("possibleFiniteStateList"u8); - if(!allowedVersionsForDefaultOption.Contains(requestedVersion)) + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleFiniteStateListItem); } - writer.WritePropertyName("defaultOption"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(publicationItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("relationship"u8); + + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(relationshipItem); } - break; - case "diagramcanvas": - var allowedVersionsForDiagramCanvas = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("requirementsSpecification"u8); - if(!allowedVersionsForDiagramCanvas.Contains(requestedVersion)) + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requirementsSpecificationItem); } - writer.WriteStartArray("diagramCanvas"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); - if(value is IEnumerable objectListDiagramCanvas) + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) { - foreach(var diagramCanvasItem in objectListDiagramCanvas.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(diagramCanvasItem); - } + writer.WriteStringValue(ruleVerificationListItem); } - + writer.WriteEndArray(); - break; - case "domainfilestore": - var allowedVersionsForDomainFileStore = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("sourceIterationIid"u8); - if(!allowedVersionsForDomainFileStore.Contains(requestedVersion)) + if(iteration.SourceIterationIid.HasValue) { - return; + writer.WriteStringValue(iteration.SourceIterationIid.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("domainFileStore"u8); + writer.WritePropertyName("topElement"u8); - if(value is IEnumerable objectListDomainFileStore) + if(iteration.TopElement.HasValue) { - foreach(var domainFileStoreItem in objectListDomainFileStore.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainFileStoreItem); - } + writer.WriteStringValue(iteration.TopElement.Value); } - - writer.WriteEndArray(); - break; - case "element": - var allowedVersionsForElement = new List + else { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Iteration for Version 1.1.0"); + writer.WriteStartArray("actualFiniteStateList"u8); - if(!allowedVersionsForElement.Contains(requestedVersion)) + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(actualFiniteStateListItem); } - writer.WriteStartArray("element"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); - if(value is IEnumerable objectListElement) + if(iteration.DefaultOption.HasValue) { - foreach(var elementItem in objectListElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(elementItem); - } + writer.WriteStringValue(iteration.DefaultOption.Value); } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } + + writer.WriteStartArray("diagramCanvas"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(diagramCanvasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("domainFileStore"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(domainFileStoreItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("element"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(elementItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "externalidentifiermap": - var allowedVersionsForExternalIdentifierMap = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExternalIdentifierMap.Contains(requestedVersion)) + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); - if(value is IEnumerable objectListExternalIdentifierMap) + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) { - foreach(var externalIdentifierMapItem in objectListExternalIdentifierMap.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(externalIdentifierMapItem); - } + writer.WriteStringValue(externalIdentifierMapItem); } - + writer.WriteEndArray(); - break; - case "goal": - var allowedVersionsForGoal = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("goal"u8); - if(!allowedVersionsForGoal.Contains(requestedVersion)) + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(goalItem); } - writer.WriteStartArray("goal"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("option"u8); - if(value is IEnumerable objectListGoal) + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(goalItem); - } + writer.WriteOrderedItem(optionItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("possibleFiniteStateList"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleFiniteStateListItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("publication"u8); + + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(publicationItem); } - break; - case "iterationsetup": - var allowedVersionsForIterationSetup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("relationship"u8); - if(!allowedVersionsForIterationSetup.Contains(requestedVersion)) + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relationshipItem); } - writer.WritePropertyName("iterationSetup"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("requirementsSpecification"u8); + + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requirementsSpecificationItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); + + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(ruleVerificationListItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("sharedDiagramStyle"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sharedDiagramStyleItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(iteration.SourceIterationIid.Value); } else { writer.WriteNullValue(); } - break; - case "option": - var allowedVersionsForOption = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("stakeholder"u8); - if(!allowedVersionsForOption.Contains(requestedVersion)) + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderItem); } - writer.WriteStartArray("option"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("stakeholderValue"u8); - if(value is IEnumerable objectListOption) + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var optionItem in objectListOption.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(optionItem); - } + writer.WriteStringValue(stakeholderValueItem); } - + writer.WriteEndArray(); - break; - case "possiblefinitestatelist": - var allowedVersionsForPossibleFiniteStateList = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("stakeholderValueMap"u8); - if(!allowedVersionsForPossibleFiniteStateList.Contains(requestedVersion)) + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderValueMapItem); } - writer.WriteStartArray("possibleFiniteStateList"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("topElement"u8); - if(value is IEnumerable objectListPossibleFiniteStateList) + if(iteration.TopElement.HasValue) { - foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(possibleFiniteStateListItem); - } + writer.WriteStringValue(iteration.TopElement.Value); } - - writer.WriteEndArray(); - break; - case "publication": - var allowedVersionsForPublication = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPublication.Contains(requestedVersion)) + else { - return; + writer.WriteNullValue(); } - writer.WriteStartArray("publication"u8); + writer.WriteStartArray("valueGroup"u8); - if(value is IEnumerable objectListPublication) + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) { - foreach(var publicationItem in objectListPublication.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(publicationItem); - } + writer.WriteStringValue(valueGroupItem); } - + writer.WriteEndArray(); + break; - case "relationship": - var allowedVersionsForRelationship = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Iteration for Version 1.2.0"); + writer.WriteStartArray("actualFiniteStateList"u8); - if(!allowedVersionsForRelationship.Contains(requestedVersion)) + foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(actualFiniteStateListItem); } - writer.WriteStartArray("relationship"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iteration.ClassKind.ToString()); + writer.WritePropertyName("defaultOption"u8); - if(value is IEnumerable objectListRelationship) + if(iteration.DefaultOption.HasValue) { - foreach(var relationshipItem in objectListRelationship.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relationshipItem); - } + writer.WriteStringValue(iteration.DefaultOption.Value); } - - writer.WriteEndArray(); - break; - case "requirementsspecification": - var allowedVersionsForRequirementsSpecification = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRequirementsSpecification.Contains(requestedVersion)) + else { - return; + writer.WriteNullValue(); } - writer.WriteStartArray("requirementsSpecification"u8); + writer.WriteStartArray("diagramCanvas"u8); - if(value is IEnumerable objectListRequirementsSpecification) + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) { - foreach(var requirementsSpecificationItem in objectListRequirementsSpecification.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(requirementsSpecificationItem); - } + writer.WriteStringValue(diagramCanvasItem); } - + writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("domainFileStore"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainFileStoreItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "ruleverificationlist": - var allowedVersionsForRuleVerificationList = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("element"u8); - if(!allowedVersionsForRuleVerificationList.Contains(requestedVersion)) + foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(elementItem); } - writer.WriteStartArray("ruleVerificationList"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListRuleVerificationList) + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var ruleVerificationListItem in objectListRuleVerificationList.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(ruleVerificationListItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "shareddiagramstyle": - var allowedVersionsForSharedDiagramStyle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForSharedDiagramStyle.Contains(requestedVersion)) + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("sharedDiagramStyle"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("externalIdentifierMap"u8); - if(value is IEnumerable objectListSharedDiagramStyle) + foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) { - foreach(var sharedDiagramStyleItem in objectListSharedDiagramStyle.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sharedDiagramStyleItem); - } + writer.WriteStringValue(externalIdentifierMapItem); } - + writer.WriteEndArray(); - break; - case "sourceiterationiid": - var allowedVersionsForSourceIterationIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("goal"u8); - if(!allowedVersionsForSourceIterationIid.Contains(requestedVersion)) + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(goalItem); } - writer.WritePropertyName("sourceIterationIid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "stakeholder": - var allowedVersionsForStakeholder = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iteration.Iid); + writer.WritePropertyName("iterationSetup"u8); + writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("option"u8); - if(!allowedVersionsForStakeholder.Contains(requestedVersion)) + foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(optionItem); } - writer.WriteStartArray("stakeholder"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("possibleFiniteStateList"u8); - if(value is IEnumerable objectListStakeholder) + foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) { - foreach(var stakeholderItem in objectListStakeholder.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderItem); - } + writer.WriteStringValue(possibleFiniteStateListItem); } - + writer.WriteEndArray(); - break; - case "stakeholdervalue": - var allowedVersionsForStakeholderValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("publication"u8); - if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(publicationItem); } - writer.WriteStartArray("stakeholderValue"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("relationship"u8); - if(value is IEnumerable objectListStakeholderValue) + foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) { - foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderValueItem); - } + writer.WriteStringValue(relationshipItem); } - + writer.WriteEndArray(); - break; - case "stakeholdervaluemap": - var allowedVersionsForStakeholderValueMap = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("requirementsSpecification"u8); - if(!allowedVersionsForStakeholderValueMap.Contains(requestedVersion)) + foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requirementsSpecificationItem); } - writer.WriteStartArray("stakeholderValueMap"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iteration.RevisionNumber); + writer.WriteStartArray("ruleVerificationList"u8); - if(value is IEnumerable objectListStakeholderValueMap) + foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) { - foreach(var stakeholderValueMapItem in objectListStakeholderValueMap.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderValueMapItem); - } + writer.WriteStringValue(ruleVerificationListItem); } - + writer.WriteEndArray(); - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("sharedDiagramStyle"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sharedDiagramStyleItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("sourceIterationIid"u8); + + if(iteration.SourceIterationIid.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(iteration.SourceIterationIid.Value); } else { writer.WriteNullValue(); } - break; - case "topelement": - var allowedVersionsForTopElement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("stakeholder"u8); - if(!allowedVersionsForTopElement.Contains(requestedVersion)) + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderItem); } - writer.WritePropertyName("topElement"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(stakeholderValueItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("stakeholderValueMap"u8); + + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(stakeholderValueMapItem); } - break; - case "valuegroup": - var allowedVersionsForValueGroup = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iteration.ThingPreference); + writer.WritePropertyName("topElement"u8); - if(!allowedVersionsForValueGroup.Contains(requestedVersion)) + if(iteration.TopElement.HasValue) { - return; + writer.WriteStringValue(iteration.TopElement.Value); + } + else + { + writer.WriteNullValue(); } writer.WriteStartArray("valueGroup"u8); - if(value is IEnumerable objectListValueGroup) + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) { - foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueGroupItem); - } + writer.WriteStringValue(valueGroupItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Iteration"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Iteration iteration) - { - throw new ArgumentException("The thing shall be a Iteration", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Iteration since Version is below 1.0.0"); - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Iteration for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WriteStartObject(); + if(iteration.Actor.HasValue) + { + writer.WriteStringValue(iteration.Actor.Value); + } + else + { + writer.WriteNullValue(); + } - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.0.0"); writer.WriteStartArray("actualFiniteStateList"u8); foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) @@ -841,6 +666,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(iteration.ClassKind.ToString()); writer.WritePropertyName("defaultOption"u8); @@ -854,6 +680,15 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } + writer.WriteStartArray("diagramCanvas"u8); + + foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("domainFileStore"u8); foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) @@ -862,6 +697,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("element"u8); foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) @@ -870,6 +706,25 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("externalIdentifierMap"u8); foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) @@ -878,10 +733,22 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("goal"u8); + + foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(iteration.Iid); writer.WritePropertyName("iterationSetup"u8); writer.WriteStringValue(iteration.IterationSetup); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WriteStartArray("option"u8); foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) @@ -890,6 +757,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("possibleFiniteStateList"u8); foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) @@ -898,6 +766,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("publication"u8); foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) @@ -906,6 +775,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("relationship"u8); foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) @@ -914,6 +784,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("requirementsSpecification"u8); foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) @@ -922,6 +793,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(iteration.RevisionNumber); writer.WriteStartArray("ruleVerificationList"u8); @@ -932,644 +804,660 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); - writer.WritePropertyName("sourceIterationIid"u8); + + writer.WriteStartArray("sharedDiagramStyle"u8); - if(iteration.SourceIterationIid.HasValue) - { - writer.WriteStringValue(iteration.SourceIterationIid.Value); - } - else + foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(sharedDiagramStyleItem); } - writer.WritePropertyName("topElement"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("sourceIterationIid"u8); - if(iteration.TopElement.HasValue) + if(iteration.SourceIterationIid.HasValue) { - writer.WriteStringValue(iteration.TopElement.Value); + writer.WriteStringValue(iteration.SourceIterationIid.Value); } else { writer.WriteNullValue(); } - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.1.0"); - writer.WriteStartArray("actualFiniteStateList"u8); + writer.WriteStartArray("stakeholder"u8); - foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(actualFiniteStateListItem); + writer.WriteStringValue(stakeholderItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iteration.ClassKind.ToString()); - writer.WritePropertyName("defaultOption"u8); + + writer.WriteStartArray("stakeholderValue"u8); - if(iteration.DefaultOption.HasValue) - { - writer.WriteStringValue(iteration.DefaultOption.Value); - } - else + foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(stakeholderValueItem); } - writer.WriteStartArray("diagramCanvas"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("stakeholderValueMap"u8); - foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(diagramCanvasItem); + writer.WriteStringValue(stakeholderValueMapItem); } writer.WriteEndArray(); - writer.WriteStartArray("domainFileStore"u8); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iteration.ThingPreference); + writer.WritePropertyName("topElement"u8); - foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + if(iteration.TopElement.HasValue) { - writer.WriteStringValue(domainFileStoreItem); + writer.WriteStringValue(iteration.TopElement.Value); } - - writer.WriteEndArray(); - writer.WriteStartArray("element"u8); - - foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(elementItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("valueGroup"u8); - foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue(valueGroupItem); } writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WriteStartArray("externalIdentifierMap"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(externalIdentifierMapItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("goal"u8); - - foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("actor"u8); + + if(value != null) { - writer.WriteStringValue(goalItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iteration.Iid); - writer.WritePropertyName("iterationSetup"u8); - writer.WriteStringValue(iteration.IterationSetup); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("option"u8); - - foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(optionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("possibleFiniteStateList"u8); - - foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + break; + case "actualfinitestatelist": + if(!AllowedVersionsPerProperty["actualFiniteStateList"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleFiniteStateListItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("publication"u8); + writer.WriteStartArray("actualFiniteStateList"u8); - foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListActualFiniteStateList) { - writer.WriteStringValue(publicationItem); + foreach(var actualFiniteStateListItem in objectListActualFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(actualFiniteStateListItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("relationship"u8); - - foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { - writer.WriteStringValue(relationshipItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("requirementsSpecification"u8); - - foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("classKind"u8); + + if(value != null) { - writer.WriteStringValue(requirementsSpecificationItem); + writer.WriteStringValue(((ClassKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iteration.RevisionNumber); - writer.WriteStartArray("ruleVerificationList"u8); - - foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(ruleVerificationListItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("sharedDiagramStyle"u8); - - foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "defaultoption": + if(!AllowedVersionsPerProperty["defaultOption"].Contains(requestedVersion)) { - writer.WriteStringValue(sharedDiagramStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("sourceIterationIid"u8); - - if(iteration.SourceIterationIid.HasValue) + writer.WritePropertyName("defaultOption"u8); + + if(value != null) { - writer.WriteStringValue(iteration.SourceIterationIid.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("stakeholder"u8); - - foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + break; + case "diagramcanvas": + if(!AllowedVersionsPerProperty["diagramCanvas"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderValueItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValueMap"u8); + writer.WriteStartArray("diagramCanvas"u8); - foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDiagramCanvas) { - writer.WriteStringValue(stakeholderValueMapItem); + foreach(var diagramCanvasItem in objectListDiagramCanvas.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(diagramCanvasItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("topElement"u8); - - if(iteration.TopElement.HasValue) - { - writer.WriteStringValue(iteration.TopElement.Value); - } - else + break; + case "domainfilestore": + if(!AllowedVersionsPerProperty["domainFileStore"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("valueGroup"u8); + writer.WriteStartArray("domainFileStore"u8); - foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDomainFileStore) { - writer.WriteStringValue(valueGroupItem); + foreach(var domainFileStoreItem in objectListDomainFileStore.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainFileStoreItem); + } } - + writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.2.0"); - writer.WriteStartArray("actualFiniteStateList"u8); - - foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + case "element": + if(!AllowedVersionsPerProperty["element"].Contains(requestedVersion)) { - writer.WriteStringValue(actualFiniteStateListItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iteration.ClassKind.ToString()); - writer.WritePropertyName("defaultOption"u8); + writer.WriteStartArray("element"u8); - if(iteration.DefaultOption.HasValue) + if(value is IEnumerable objectListElement) { - writer.WriteStringValue(iteration.DefaultOption.Value); + foreach(var elementItem in objectListElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(elementItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("diagramCanvas"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(diagramCanvasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("domainFileStore"u8); - - foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(domainFileStoreItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("element"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(elementItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "externalidentifiermap": + if(!AllowedVersionsPerProperty["externalIdentifierMap"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("externalIdentifierMap"u8); - foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExternalIdentifierMap) { - writer.WriteStringValue(excludedPersonItem); + foreach(var externalIdentifierMapItem in objectListExternalIdentifierMap.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(externalIdentifierMapItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("externalIdentifierMap"u8); - - foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + break; + case "goal": + if(!AllowedVersionsPerProperty["goal"].Contains(requestedVersion)) { - writer.WriteStringValue(externalIdentifierMapItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("goal"u8); - foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGoal) { - writer.WriteStringValue(goalItem); + foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iteration.Iid); - writer.WritePropertyName("iterationSetup"u8); - writer.WriteStringValue(iteration.IterationSetup); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("option"u8); - - foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteOrderedItem(optionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("possibleFiniteStateList"u8); - - foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(possibleFiniteStateListItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("publication"u8); - - foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(publicationItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("relationship"u8); - - foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + break; + case "iterationsetup": + if(!AllowedVersionsPerProperty["iterationSetup"].Contains(requestedVersion)) { - writer.WriteStringValue(relationshipItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("requirementsSpecification"u8); - - foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iterationSetup"u8); + + if(value != null) { - writer.WriteStringValue(requirementsSpecificationItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iteration.RevisionNumber); - writer.WriteStartArray("ruleVerificationList"u8); - - foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(ruleVerificationListItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("sharedDiagramStyle"u8); - - foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(sharedDiagramStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("sourceIterationIid"u8); - - if(iteration.SourceIterationIid.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(iteration.SourceIterationIid.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("stakeholder"u8); - - foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) + break; + case "option": + if(!AllowedVersionsPerProperty["option"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValue"u8); + writer.WriteStartArray("option"u8); - foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListOption) { - writer.WriteStringValue(stakeholderValueItem); + foreach(var optionItem in objectListOption.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(optionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValueMap"u8); - - foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + break; + case "possiblefinitestatelist": + if(!AllowedVersionsPerProperty["possibleFiniteStateList"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderValueMapItem); + return; } + writer.WriteStartArray("possibleFiniteStateList"u8); + + if(value is IEnumerable objectListPossibleFiniteStateList) + { + foreach(var possibleFiniteStateListItem in objectListPossibleFiniteStateList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleFiniteStateListItem); + } + } + writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(iteration.ThingPreference); - writer.WritePropertyName("topElement"u8); + break; + case "publication": + if(!AllowedVersionsPerProperty["publication"].Contains(requestedVersion)) + { + return; + } - if(iteration.TopElement.HasValue) + writer.WriteStartArray("publication"u8); + + if(value is IEnumerable objectListPublication) { - writer.WriteStringValue(iteration.TopElement.Value); + foreach(var publicationItem in objectListPublication.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publicationItem); + } } - else + + writer.WriteEndArray(); + break; + case "relationship": + if(!AllowedVersionsPerProperty["relationship"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("valueGroup"u8); + writer.WriteStartArray("relationship"u8); - foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelationship) { - writer.WriteStringValue(valueGroupItem); + foreach(var relationshipItem in objectListRelationship.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relationshipItem); + } } - + writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Iteration for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(iteration.Actor.HasValue) - { - writer.WriteStringValue(iteration.Actor.Value); - } - else + case "requirementsspecification": + if(!AllowedVersionsPerProperty["requirementsSpecification"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("actualFiniteStateList"u8); + writer.WriteStartArray("requirementsSpecification"u8); - foreach(var actualFiniteStateListItem in iteration.ActualFiniteStateList.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRequirementsSpecification) { - writer.WriteStringValue(actualFiniteStateListItem); + foreach(var requirementsSpecificationItem in objectListRequirementsSpecification.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementsSpecificationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iteration.ClassKind.ToString()); - writer.WritePropertyName("defaultOption"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(iteration.DefaultOption.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(iteration.DefaultOption.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("diagramCanvas"u8); - - foreach(var diagramCanvasItem in iteration.DiagramCanvas.OrderBy(x => x, this.GuidComparer)) + break; + case "ruleverificationlist": + if(!AllowedVersionsPerProperty["ruleVerificationList"].Contains(requestedVersion)) { - writer.WriteStringValue(diagramCanvasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("domainFileStore"u8); + writer.WriteStartArray("ruleVerificationList"u8); - foreach(var domainFileStoreItem in iteration.DomainFileStore.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRuleVerificationList) { - writer.WriteStringValue(domainFileStoreItem); + foreach(var ruleVerificationListItem in objectListRuleVerificationList.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleVerificationListItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("element"u8); - - foreach(var elementItem in iteration.Element.OrderBy(x => x, this.GuidComparer)) + break; + case "shareddiagramstyle": + if(!AllowedVersionsPerProperty["sharedDiagramStyle"].Contains(requestedVersion)) { - writer.WriteStringValue(elementItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("sharedDiagramStyle"u8); - foreach(var excludedDomainItem in iteration.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSharedDiagramStyle) { - writer.WriteStringValue(excludedDomainItem); + foreach(var sharedDiagramStyleItem in objectListSharedDiagramStyle.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sharedDiagramStyleItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in iteration.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceiterationiid": + if(!AllowedVersionsPerProperty["sourceIterationIid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("externalIdentifierMap"u8); - - foreach(var externalIdentifierMapItem in iteration.ExternalIdentifierMap.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("sourceIterationIid"u8); + + if(value != null) { - writer.WriteStringValue(externalIdentifierMapItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("goal"u8); - - foreach(var goalItem in iteration.Goal.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(goalItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iteration.Iid); - writer.WritePropertyName("iterationSetup"u8); - writer.WriteStringValue(iteration.IterationSetup); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iteration.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("option"u8); - - foreach(var optionItem in iteration.Option.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "stakeholder": + if(!AllowedVersionsPerProperty["stakeholder"].Contains(requestedVersion)) { - writer.WriteOrderedItem(optionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("possibleFiniteStateList"u8); + writer.WriteStartArray("stakeholder"u8); - foreach(var possibleFiniteStateListItem in iteration.PossibleFiniteStateList.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListStakeholder) { - writer.WriteStringValue(possibleFiniteStateListItem); + foreach(var stakeholderItem in objectListStakeholder.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("publication"u8); - - foreach(var publicationItem in iteration.Publication.OrderBy(x => x, this.GuidComparer)) + break; + case "stakeholdervalue": + if(!AllowedVersionsPerProperty["stakeholderValue"].Contains(requestedVersion)) { - writer.WriteStringValue(publicationItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("relationship"u8); + writer.WriteStartArray("stakeholderValue"u8); - foreach(var relationshipItem in iteration.Relationship.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListStakeholderValue) { - writer.WriteStringValue(relationshipItem); + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("requirementsSpecification"u8); - - foreach(var requirementsSpecificationItem in iteration.RequirementsSpecification.OrderBy(x => x, this.GuidComparer)) + break; + case "stakeholdervaluemap": + if(!AllowedVersionsPerProperty["stakeholderValueMap"].Contains(requestedVersion)) { - writer.WriteStringValue(requirementsSpecificationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iteration.RevisionNumber); - writer.WriteStartArray("ruleVerificationList"u8); + writer.WriteStartArray("stakeholderValueMap"u8); - foreach(var ruleVerificationListItem in iteration.RuleVerificationList.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListStakeholderValueMap) { - writer.WriteStringValue(ruleVerificationListItem); + foreach(var stakeholderValueMapItem in objectListStakeholderValueMap.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueMapItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("sharedDiagramStyle"u8); - - foreach(var sharedDiagramStyleItem in iteration.SharedDiagramStyle.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(sharedDiagramStyleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("sourceIterationIid"u8); - - if(iteration.SourceIterationIid.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(iteration.SourceIterationIid.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("stakeholder"u8); - - foreach(var stakeholderItem in iteration.Stakeholder.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in iteration.StakeholderValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("stakeholderValueMap"u8); - - foreach(var stakeholderValueMapItem in iteration.StakeholderValueMap.OrderBy(x => x, this.GuidComparer)) + break; + case "topelement": + if(!AllowedVersionsPerProperty["topElement"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderValueMapItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(iteration.ThingPreference); writer.WritePropertyName("topElement"u8); - - if(iteration.TopElement.HasValue) + + if(value != null) { - writer.WriteStringValue(iteration.TopElement.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "valuegroup": + if(!AllowedVersionsPerProperty["valueGroup"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("valueGroup"u8); - foreach(var valueGroupItem in iteration.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListValueGroup) { - writer.WriteStringValue(valueGroupItem); + foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Iteration"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "actualFiniteStateList", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultOption", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "diagramCanvas", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "domainFileStore", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "element", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "externalIdentifierMap", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "goal", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iterationSetup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "option", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleFiniteStateList", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "publication", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "relationship", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "requirementsSpecification", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "ruleVerificationList", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "sharedDiagramStyle", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceIterationIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholder", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholderValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholderValueMap", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "topElement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueGroup", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs index 5f6ab1369..ade206847 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/IterationSetupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,60 +51,64 @@ namespace CDP4JsonSerializer public class IterationSetupSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not IterationSetup iterationSetup) + { + throw new ArgumentException("The thing shall be a IterationSetup", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of IterationSetup since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing IterationSetup for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); - writer.WritePropertyName("classKind"u8); - - if(value != null) + if(iterationSetup.SourceIterationSetup.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); } else { @@ -111,304 +116,232 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing IterationSetup for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "description": - var allowedVersionsForDescription = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDescription.Contains(requestedVersion)) + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("description"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(iterationSetup.SourceIterationSetup.HasValue) { - return; + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) + else { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteNullValue(); } - - writer.WriteEndArray(); + break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing IterationSetup for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "frozenon": - var allowedVersionsForFrozenOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForFrozenOn.Contains(requestedVersion)) + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("frozenOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("iid"u8); - - if(value != null) + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iterationSetup.ThingPreference); break; - case "isdeleted": - var allowedVersionsForIsDeleted = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeleted.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing IterationSetup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("isDeleted"u8); - - if(value != null) + if(iterationSetup.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(iterationSetup.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "iterationiid": - var allowedVersionsForIterationIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(iterationSetup.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(iterationSetup.Description); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIterationIid.Contains(requestedVersion)) + foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("iterationIid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "iterationnumber": - var allowedVersionsForIterationNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIterationNumber.Contains(requestedVersion)) + foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("iterationNumber"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("frozenOn"u8); + + if(iterationSetup.FrozenOn.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(iterationSetup.Iid); + writer.WritePropertyName("isDeleted"u8); + writer.WriteBooleanValue(iterationSetup.IsDeleted); + writer.WritePropertyName("iterationIid"u8); + writer.WriteStringValue(iterationSetup.IterationIid); + writer.WritePropertyName("iterationNumber"u8); + writer.WriteNumberValue(iterationSetup.IterationNumber); writer.WritePropertyName("modifiedOn"u8); - - if(value != null) + writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(iterationSetup.RevisionNumber); + writer.WritePropertyName("sourceIterationSetup"u8); + + if(iterationSetup.SourceIterationSetup.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); } else { writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(iterationSetup.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } + writer.WriteEndObject(); + } - break; - case "sourceiterationsetup": - var allowedVersionsForSourceIterationSetup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForSourceIterationSetup.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("sourceIterationSetup"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -420,94 +353,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { writer.WriteNullValue(); } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the IterationSetup"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not IterationSetup iterationSetup) - { - throw new ArgumentException("The thing shall be a IterationSetup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of IterationSetup since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iterationSetup.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(iterationSetup.Description); - writer.WritePropertyName("frozenOn"u8); - - if(iterationSetup.FrozenOn.HasValue) + break; + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { - writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + return; + } + + writer.WritePropertyName("createdOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iterationSetup.Iid); - writer.WritePropertyName("isDeleted"u8); - writer.WriteBooleanValue(iterationSetup.IsDeleted); - writer.WritePropertyName("iterationIid"u8); - writer.WriteStringValue(iterationSetup.IterationIid); - writer.WritePropertyName("iterationNumber"u8); - writer.WriteNumberValue(iterationSetup.IterationNumber); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iterationSetup.RevisionNumber); - writer.WritePropertyName("sourceIterationSetup"u8); + break; + case "description": + if(!AllowedVersionsPerProperty["description"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.SourceIterationSetup.HasValue) + writer.WritePropertyName("description"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + writer.WriteStringValue((string)value); } else { @@ -515,58 +407,71 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iterationSetup.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(iterationSetup.Description); + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("frozenOn"u8); + break; + case "frozenon": + if(!AllowedVersionsPerProperty["frozenOn"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.FrozenOn.HasValue) + writer.WritePropertyName("frozenOn"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iterationSetup.Iid); - writer.WritePropertyName("isDeleted"u8); - writer.WriteBooleanValue(iterationSetup.IsDeleted); - writer.WritePropertyName("iterationIid"u8); - writer.WriteStringValue(iterationSetup.IterationIid); - writer.WritePropertyName("iterationNumber"u8); - writer.WriteNumberValue(iterationSetup.IterationNumber); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iterationSetup.RevisionNumber); - writer.WritePropertyName("sourceIterationSetup"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.SourceIterationSetup.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + writer.WriteStringValue((Guid)value); } else { @@ -574,145 +479,158 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iterationSetup.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(iterationSetup.Description); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + case "isdeleted": + if(!AllowedVersionsPerProperty["isDeleted"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeleted"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("frozenOn"u8); + break; + case "iterationiid": + if(!AllowedVersionsPerProperty["iterationIid"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.FrozenOn.HasValue) + writer.WritePropertyName("iterationIid"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iterationSetup.Iid); - writer.WritePropertyName("isDeleted"u8); - writer.WriteBooleanValue(iterationSetup.IsDeleted); - writer.WritePropertyName("iterationIid"u8); - writer.WriteStringValue(iterationSetup.IterationIid); - writer.WritePropertyName("iterationNumber"u8); - writer.WriteNumberValue(iterationSetup.IterationNumber); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iterationSetup.RevisionNumber); - writer.WritePropertyName("sourceIterationSetup"u8); + break; + case "iterationnumber": + if(!AllowedVersionsPerProperty["iterationNumber"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.SourceIterationSetup.HasValue) + writer.WritePropertyName("iterationNumber"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(iterationSetup.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing IterationSetup for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.Actor.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(iterationSetup.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(iterationSetup.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(iterationSetup.Description); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in iterationSetup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in iterationSetup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("frozenOn"u8); + break; + case "sourceiterationsetup": + if(!AllowedVersionsPerProperty["sourceIterationSetup"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.FrozenOn.HasValue) + writer.WritePropertyName("sourceIterationSetup"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.FrozenOn.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(iterationSetup.Iid); - writer.WritePropertyName("isDeleted"u8); - writer.WriteBooleanValue(iterationSetup.IsDeleted); - writer.WritePropertyName("iterationIid"u8); - writer.WriteStringValue(iterationSetup.IterationIid); - writer.WritePropertyName("iterationNumber"u8); - writer.WriteNumberValue(iterationSetup.IterationNumber); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(iterationSetup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(iterationSetup.RevisionNumber); - writer.WritePropertyName("sourceIterationSetup"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(iterationSetup.SourceIterationSetup.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(iterationSetup.SourceIterationSetup.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(iterationSetup.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the IterationSetup"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "description", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "frozenOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeleted", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iterationIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iterationNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceIterationSetup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs index 75ef50fd7..6a462edc1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LinearConversionUnitSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,317 +51,321 @@ namespace CDP4JsonSerializer public class LinearConversionUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not LinearConversionUnit linearConversionUnit) + { + throw new ArgumentException("The thing shall be a LinearConversionUnit", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of LinearConversionUnit since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing LinearConversionUnit for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing LinearConversionUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "conversionfactor": - var allowedVersionsForConversionFactor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForConversionFactor.Contains(requestedVersion)) + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("conversionFactor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing LinearConversionUnit for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(linearConversionUnit.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing LinearConversionUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(linearConversionUnit.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(linearConversionUnit.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(linearConversionUnit.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(linearConversionUnit.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(linearConversionUnit.Name); + writer.WritePropertyName("referenceUnit"u8); + writer.WriteStringValue(linearConversionUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(linearConversionUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(linearConversionUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(linearConversionUnit.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForName.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -368,25 +373,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "referenceunit": - var allowedVersionsForReferenceUnit = new List + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForReferenceUnit.Contains(requestedVersion)) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("referenceUnit"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -394,25 +409,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "conversionfactor": + if(!AllowedVersionsPerProperty["conversionFactor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("conversionFactor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((string)value); } else { @@ -420,49 +427,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForShortName.Contains(requestedVersion)) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue((string)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -470,283 +517,159 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the LinearConversionUnit"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not LinearConversionUnit linearConversionUnit) - { - throw new ArgumentException("The thing shall be a LinearConversionUnit", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of LinearConversionUnit since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(linearConversionUnit.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(linearConversionUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(linearConversionUnit.Name); - writer.WritePropertyName("referenceUnit"u8); - writer.WriteStringValue(linearConversionUnit.ReferenceUnit); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(linearConversionUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(linearConversionUnit.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(linearConversionUnit.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(linearConversionUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(linearConversionUnit.Name); - writer.WritePropertyName("referenceUnit"u8); - writer.WriteStringValue(linearConversionUnit.ReferenceUnit); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(linearConversionUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(linearConversionUnit.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(linearConversionUnit.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "referenceunit": + if(!AllowedVersionsPerProperty["referenceUnit"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("referenceUnit"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(linearConversionUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(linearConversionUnit.Name); - writer.WritePropertyName("referenceUnit"u8); - writer.WriteStringValue(linearConversionUnit.ReferenceUnit); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(linearConversionUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(linearConversionUnit.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(linearConversionUnit.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing LinearConversionUnit for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(linearConversionUnit.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(linearConversionUnit.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in linearConversionUnit.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(linearConversionUnit.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(linearConversionUnit.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in linearConversionUnit.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in linearConversionUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in linearConversionUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in linearConversionUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(linearConversionUnit.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(linearConversionUnit.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(linearConversionUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(linearConversionUnit.Name); - writer.WritePropertyName("referenceUnit"u8); - writer.WriteStringValue(linearConversionUnit.ReferenceUnit); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(linearConversionUnit.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(linearConversionUnit.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(linearConversionUnit.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the LinearConversionUnit"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "conversionFactor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceUnit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs index bb2eb50c7..b6919f1eb 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LogEntryChangelogItemSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,141 @@ namespace CDP4JsonSerializer /// public class LogEntryChangelogItemSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not LogEntryChangelogItem logEntryChangelogItem) + { + throw new ArgumentException("The thing shall be a LogEntryChangelogItem", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of LogEntryChangelogItem since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing LogEntryChangelogItem for Version 1.2.0"); + writer.WritePropertyName("affectedItemIid"u8); + writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); + writer.WriteStartArray("affectedReferenceIid"u8); + + foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) + { + writer.WriteStringValue(affectedReferenceIidItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("changeDescription"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); + writer.WritePropertyName("changelogKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logEntryChangelogItem.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logEntryChangelogItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing LogEntryChangelogItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(logEntryChangelogItem.Actor.HasValue) + { + writer.WriteStringValue(logEntryChangelogItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("affectedItemIid"u8); + writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); + writer.WriteStartArray("affectedReferenceIid"u8); + + foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) + { + writer.WriteStringValue(affectedReferenceIidItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("changeDescription"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); + writer.WritePropertyName("changelogKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logEntryChangelogItem.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logEntryChangelogItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +192,7 @@ public class LogEntryChangelogItemSerializer : BaseThingSerializer, IThingSerial /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +200,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,13 +218,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "affecteditemiid": - var allowedVersionsForAffectedItemIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["affectedItemIid"].Contains(requestedVersion)) { return; } @@ -110,13 +236,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "affectedreferenceiid": - var allowedVersionsForAffectedReferenceIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAffectedReferenceIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["affectedReferenceIid"].Contains(requestedVersion)) { return; } @@ -134,13 +254,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "changedescription": - var allowedVersionsForChangeDescription = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForChangeDescription.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["changeDescription"].Contains(requestedVersion)) { return; } @@ -158,13 +272,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "changelogkind": - var allowedVersionsForChangelogKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForChangelogKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["changelogKind"].Contains(requestedVersion)) { return; } @@ -182,13 +290,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -206,14 +308,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -231,14 +326,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -256,13 +344,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -280,14 +362,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -305,13 +380,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -329,13 +398,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -358,133 +421,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not LogEntryChangelogItem logEntryChangelogItem) - { - throw new ArgumentException("The thing shall be a LogEntryChangelogItem", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.2.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of LogEntryChangelogItem since Version is below 1.2.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing LogEntryChangelogItem for Version 1.2.0"); - writer.WritePropertyName("affectedItemIid"u8); - writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); - writer.WriteStartArray("affectedReferenceIid"u8); - - foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) - { - writer.WriteStringValue(affectedReferenceIidItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeDescription"u8); - writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); - writer.WritePropertyName("changelogKind"u8); - writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logEntryChangelogItem.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(logEntryChangelogItem.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing LogEntryChangelogItem for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(logEntryChangelogItem.Actor.HasValue) - { - writer.WriteStringValue(logEntryChangelogItem.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("affectedItemIid"u8); - writer.WriteStringValue(logEntryChangelogItem.AffectedItemIid); - writer.WriteStartArray("affectedReferenceIid"u8); - - foreach(var affectedReferenceIidItem in logEntryChangelogItem.AffectedReferenceIid) - { - writer.WriteStringValue(affectedReferenceIidItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("changeDescription"u8); - writer.WriteStringValue(logEntryChangelogItem.ChangeDescription); - writer.WritePropertyName("changelogKind"u8); - writer.WriteStringValue(logEntryChangelogItem.ChangelogKind.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logEntryChangelogItem.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in logEntryChangelogItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in logEntryChangelogItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logEntryChangelogItem.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(logEntryChangelogItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logEntryChangelogItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(logEntryChangelogItem.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "affectedItemIid", new []{ "1.2.0", "1.3.0" }}, + { "affectedReferenceIid", new []{ "1.2.0", "1.3.0" }}, + { "changeDescription", new []{ "1.2.0", "1.3.0" }}, + { "changelogKind", new []{ "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs index efd6a6ffa..04e2d9987 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/LogarithmicScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,370 +51,509 @@ namespace CDP4JsonSerializer public class LogarithmicScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not LogarithmicScale logarithmicScale) + { + throw new ArgumentException("The thing shall be a LogarithmicScale", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of LogarithmicScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing LogarithmicScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListAlias) + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(mappingToReferenceScaleItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceQuantityValueItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing LogarithmicScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(mappingToReferenceScaleItem); } - + writer.WriteEndArray(); - break; - case "exponent": - var allowedVersionsForExponent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); - if(!allowedVersionsForExponent.Contains(requestedVersion)) + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceQuantityValueItem); } - writer.WritePropertyName("exponent"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "factor": - var allowedVersionsForFactor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing LogarithmicScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForFactor.Contains(requestedVersion)) + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("factor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(mappingToReferenceScaleItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(referenceQuantityValueItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logarithmicScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing LogarithmicScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(logarithmicScale.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(logarithmicScale.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "ismaximuminclusive": - var allowedVersionsForIsMaximumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "isminimuminclusive": - var allowedVersionsForIsMinimumInclusive = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(logarithmicScale.Exponent); + writer.WritePropertyName("factor"u8); + writer.WriteStringValue(logarithmicScale.Factor); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(logarithmicScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(logarithmicScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); + writer.WritePropertyName("logarithmBase"u8); + writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(logarithmicScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); + writer.WritePropertyName("referenceQuantityKind"u8); + writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); + writer.WriteStartArray("referenceQuantityValue"u8); + + foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(referenceQuantityValueItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(logarithmicScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(logarithmicScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(logarithmicScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(logarithmicScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "logarithmbase": - var allowedVersionsForLogarithmBase = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForLogarithmBase.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("logarithmBase"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue(((LogarithmBaseKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -421,47 +561,103 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "mappingtoreferencescale": - var allowedVersionsForMappingToReferenceScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("mappingToReferenceScale"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListMappingToReferenceScale) + if(value is IEnumerable objectListAlias) { - foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "maximumpermissiblevalue": - var allowedVersionsForMaximumPermissibleValue = new List + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "exponent": + if(!AllowedVersionsPerProperty["exponent"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("exponent"u8); if(value != null) { @@ -473,21 +669,157 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "minimumpermissiblevalue": - var allowedVersionsForMinimumPermissibleValue = new List + case "factor": + if(!AllowedVersionsPerProperty["factor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("factor"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "ismaximuminclusive": + if(!AllowedVersionsPerProperty["isMaximumInclusive"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + if(!AllowedVersionsPerProperty["isMinimumInclusive"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "logarithmbase": + if(!AllowedVersionsPerProperty["logarithmBase"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("logarithmBase"u8); + + if(value != null) + { + writer.WriteStringValue(((LogarithmBaseKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + if(!AllowedVersionsPerProperty["mappingToReferenceScale"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + if(!AllowedVersionsPerProperty["maximumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); if(value != null) { @@ -499,15 +831,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + case "minimumpermissiblevalue": + if(!AllowedVersionsPerProperty["minimumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -525,15 +868,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -551,15 +886,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "negativevalueconnotation": - var allowedVersionsForNegativeValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["negativeValueConnotation"].Contains(requestedVersion)) { return; } @@ -577,15 +904,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "numberset": - var allowedVersionsForNumberSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["numberSet"].Contains(requestedVersion)) { return; } @@ -603,15 +922,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "positivevalueconnotation": - var allowedVersionsForPositiveValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["positiveValueConnotation"].Contains(requestedVersion)) { return; } @@ -629,15 +940,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencequantitykind": - var allowedVersionsForReferenceQuantityKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferenceQuantityKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referenceQuantityKind"].Contains(requestedVersion)) { return; } @@ -655,15 +958,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencequantityvalue": - var allowedVersionsForReferenceQuantityValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferenceQuantityValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referenceQuantityValue"].Contains(requestedVersion)) { return; } @@ -681,15 +976,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -707,15 +994,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -733,13 +1012,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -757,15 +1030,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { return; } @@ -783,15 +1048,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valuedefinition": - var allowedVersionsForValueDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { return; } @@ -814,453 +1071,40 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not LogarithmicScale logarithmicScale) - { - throw new ArgumentException("The thing shall be a LogarithmicScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of LogarithmicScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(logarithmicScale.Exponent); - writer.WritePropertyName("factor"u8); - writer.WriteStringValue(logarithmicScale.Factor); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logarithmicScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(logarithmicScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); - writer.WritePropertyName("logarithmBase"u8); - writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(logarithmicScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); - writer.WritePropertyName("referenceQuantityKind"u8); - writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); - writer.WriteStartArray("referenceQuantityValue"u8); - - foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceQuantityValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logarithmicScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(logarithmicScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(logarithmicScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(logarithmicScale.Exponent); - writer.WritePropertyName("factor"u8); - writer.WriteStringValue(logarithmicScale.Factor); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logarithmicScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(logarithmicScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); - writer.WritePropertyName("logarithmBase"u8); - writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(logarithmicScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); - writer.WritePropertyName("referenceQuantityKind"u8); - writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); - writer.WriteStartArray("referenceQuantityValue"u8); - - foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceQuantityValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logarithmicScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(logarithmicScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(logarithmicScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(logarithmicScale.Exponent); - writer.WritePropertyName("factor"u8); - writer.WriteStringValue(logarithmicScale.Factor); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logarithmicScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(logarithmicScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); - writer.WritePropertyName("logarithmBase"u8); - writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(logarithmicScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); - writer.WritePropertyName("referenceQuantityKind"u8); - writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); - writer.WriteStartArray("referenceQuantityValue"u8); - - foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceQuantityValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logarithmicScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(logarithmicScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(logarithmicScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(logarithmicScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing LogarithmicScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(logarithmicScale.Actor.HasValue) - { - writer.WriteStringValue(logarithmicScale.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in logarithmicScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(logarithmicScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in logarithmicScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in logarithmicScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in logarithmicScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(logarithmicScale.Exponent); - writer.WritePropertyName("factor"u8); - writer.WriteStringValue(logarithmicScale.Factor); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in logarithmicScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(logarithmicScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(logarithmicScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(logarithmicScale.IsMinimumInclusive); - writer.WritePropertyName("logarithmBase"u8); - writer.WriteStringValue(logarithmicScale.LogarithmBase.ToString()); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in logarithmicScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(logarithmicScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(logarithmicScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(logarithmicScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(logarithmicScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(logarithmicScale.PositiveValueConnotation); - writer.WritePropertyName("referenceQuantityKind"u8); - writer.WriteStringValue(logarithmicScale.ReferenceQuantityKind); - writer.WriteStartArray("referenceQuantityValue"u8); - - foreach(var referenceQuantityValueItem in logarithmicScale.ReferenceQuantityValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceQuantityValueItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(logarithmicScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(logarithmicScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(logarithmicScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(logarithmicScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in logarithmicScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "exponent", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "factor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMaximumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMinimumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "logarithmBase", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "mappingToReferenceScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maximumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minimumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "negativeValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "numberSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "positiveValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceQuantityKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceQuantityValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs index f5cc23eec..4514063da 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MappingToReferenceScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class MappingToReferenceScaleSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not MappingToReferenceScale mappingToReferenceScale) + { + throw new ArgumentException("The thing shall be a MappingToReferenceScale", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of MappingToReferenceScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing MappingToReferenceScale for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing MappingToReferenceScale for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing MappingToReferenceScale for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(mappingToReferenceScale.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing MappingToReferenceScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(mappingToReferenceScale.Actor.HasValue) + { + writer.WriteStringValue(mappingToReferenceScale.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); + writer.WritePropertyName("dependentScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(mappingToReferenceScale.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referenceScaleValue"u8); + writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(mappingToReferenceScale.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class MappingToReferenceScaleSerializer : BaseThingSerializer, IThingSeri /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "dependentscalevalue": - var allowedVersionsForDependentScaleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDependentScaleValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["dependentScaleValue"].Contains(requestedVersion)) { return; } @@ -138,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencescalevalue": - var allowedVersionsForReferenceScaleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferenceScaleValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referenceScaleValue"].Contains(requestedVersion)) { return; } @@ -265,15 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not MappingToReferenceScale mappingToReferenceScale) - { - throw new ArgumentException("The thing shall be a MappingToReferenceScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of MappingToReferenceScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); - writer.WritePropertyName("dependentScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(mappingToReferenceScale.Iid); - writer.WritePropertyName("referenceScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); - writer.WritePropertyName("dependentScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(mappingToReferenceScale.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referenceScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); - writer.WritePropertyName("dependentScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(mappingToReferenceScale.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referenceScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(mappingToReferenceScale.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing MappingToReferenceScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(mappingToReferenceScale.Actor.HasValue) - { - writer.WriteStringValue(mappingToReferenceScale.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(mappingToReferenceScale.ClassKind.ToString()); - writer.WritePropertyName("dependentScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.DependentScaleValue); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in mappingToReferenceScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in mappingToReferenceScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(mappingToReferenceScale.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(mappingToReferenceScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referenceScaleValue"u8); - writer.WriteStringValue(mappingToReferenceScale.ReferenceScaleValue); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(mappingToReferenceScale.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(mappingToReferenceScale.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "dependentScaleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceScaleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs index 39cf32199..e2775bf9a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelLogEntrySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,288 +51,371 @@ namespace CDP4JsonSerializer public class ModelLogEntrySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ModelLogEntry modelLogEntry) + { + throw new ArgumentException("The thing shall be a ModelLogEntry", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List + Logger.Log(LogLevel.Info, "Skipping serialization of ModelLogEntry since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ModelLogEntry for Version 1.0.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) { - "1.3.0", - }; + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(modelLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "affecteddomainiid": - var allowedVersionsForAffectedDomainIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForAffectedDomainIid.Contains(requestedVersion)) + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("affectedDomainIid"u8); - - if(value is IEnumerable objectListAffectedDomainIid) - { - foreach(var affectedDomainIidItem in objectListAffectedDomainIid) - { - writer.WriteStringValue((Guid)affectedDomainIidItem); - } - } - writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); break; - case "affecteditemiid": - var allowedVersionsForAffectedItemIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ModelLogEntry for Version 1.1.0"); + writer.WriteStartArray("affectedDomainIid"u8); - if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) { - return; + writer.WriteStringValue(affectedDomainIidItem); } - writer.WriteStartArray("affectedItemIid"u8); - - if(value is IEnumerable objectListAffectedItemIid) - { - foreach(var affectedItemIidItem in objectListAffectedItemIid) - { - writer.WriteStringValue((Guid)affectedItemIidItem); - } - } - writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(modelLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListCategory) + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(excludedDomainItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); break; - case "classkind": - var allowedVersionsForClassKind = new List + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ModelLogEntry for Version 1.2.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(modelLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(logEntryChangelogItemItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelLogEntry.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ModelLogEntry for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modelLogEntry.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(modelLogEntry.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("affectedDomainIid"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) { - return; + writer.WriteStringValue(affectedDomainIidItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(affectedItemIidItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WritePropertyName("author"u8); + + if(modelLogEntry.Author.HasValue) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(modelLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(modelLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(modelLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(modelLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelLogEntry.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -343,51 +427,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + case "affecteddomainiid": + if(!AllowedVersionsPerProperty["affectedDomainIid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); - - if(value != null) + writer.WriteStartArray("affectedDomainIid"u8); + + if(value is IEnumerable objectListAffectedDomainIid) { - writer.WriteStringValue((string)value); + foreach(var affectedDomainIidItem in objectListAffectedDomainIid) + { + writer.WriteStringValue((Guid)affectedDomainIidItem); + } } - else + + writer.WriteEndArray(); + break; + case "affecteditemiid": + if(!AllowedVersionsPerProperty["affectedItemIid"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "level": - var allowedVersionsForLevel = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForLevel.Contains(requestedVersion)) + if(value is IEnumerable objectListAffectedItemIid) + { + foreach(var affectedItemIidItem in objectListAffectedItemIid) + { + writer.WriteStringValue((Guid)affectedItemIidItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("level"u8); + writer.WritePropertyName("author"u8); if(value != null) { - writer.WriteStringValue(((LogLevelKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -395,48 +481,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "logentrychangelogitem": - var allowedVersionsForLogEntryChangelogItem = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLogEntryChangelogItem.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("logEntryChangelogItem"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListLogEntryChangelogItem) + if(value is IEnumerable objectListCategory) { - foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(logEntryChangelogItemItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -444,25 +517,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((string)value); } else { @@ -470,23 +535,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -494,335 +553,196 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelLogEntry"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ModelLogEntry modelLogEntry) - { - throw new ArgumentException("The thing shall be a ModelLogEntry", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ModelLogEntry since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.0.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedDomainIidItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(affectedItemIidItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(modelLogEntry.Author.HasValue) - { - writer.WriteStringValue(modelLogEntry.Author.Value); - } - else + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(modelLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(modelLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(modelLogEntry.Level.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelLogEntry.RevisionNumber); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.1.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(modelLogEntry.Author.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(modelLogEntry.Author.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(modelLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("languageCode"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(modelLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(modelLogEntry.Level.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelLogEntry.RevisionNumber); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.2.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + case "level": + if(!AllowedVersionsPerProperty["level"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(modelLogEntry.Author.HasValue) + writer.WritePropertyName("level"u8); + + if(value != null) { - writer.WriteStringValue(modelLogEntry.Author.Value); + writer.WriteStringValue(((LogLevelKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(modelLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "logentrychangelogitem": + if(!AllowedVersionsPerProperty["logEntryChangelogItem"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("logEntryChangelogItem"u8); - foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListLogEntryChangelogItem) { - writer.WriteStringValue(excludedPersonItem); + foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(modelLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(modelLogEntry.Level.ToString()); - writer.WriteStartArray("logEntryChangelogItem"u8); - - foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(logEntryChangelogItemItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelLogEntry.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modelLogEntry.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ModelLogEntry for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(modelLogEntry.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(modelLogEntry.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in modelLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in modelLogEntry.AffectedItemIid) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(modelLogEntry.Author.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(modelLogEntry.Author.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in modelLogEntry.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(modelLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(modelLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modelLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modelLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(modelLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(modelLogEntry.Level.ToString()); - writer.WriteStartArray("logEntryChangelogItem"u8); - - foreach(var logEntryChangelogItemItem in modelLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(logEntryChangelogItemItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modelLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelLogEntry.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modelLogEntry.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelLogEntry"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "affectedDomainIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "affectedItemIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "level", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "logEntryChangelogItem", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs index adee5fa3f..eb5656fcc 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModelReferenceDataLibrarySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,718 +51,370 @@ namespace CDP4JsonSerializer public class ModelReferenceDataLibrarySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not ModelReferenceDataLibrary modelReferenceDataLibrary) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a ModelReferenceDataLibrary", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ModelReferenceDataLibrary since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ModelReferenceDataLibrary for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "basequantitykind": - var allowedVersionsForBaseQuantityKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForBaseQuantityKind.Contains(requestedVersion)) + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("baseQuantityKind"u8); - - if(value is IEnumerable objectListBaseQuantityKind) - { - foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(baseQuantityKindItem); - } - } - writer.WriteEndArray(); - break; - case "baseunit": - var allowedVersionsForBaseUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForBaseUnit.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("baseUnit"u8); - - if(value is IEnumerable objectListBaseUnit) - { - foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(baseUnitItem); - } - } - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("baseQuantityKind"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(baseQuantityKindItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "constant": - var allowedVersionsForConstant = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("baseUnit"u8); - if(!allowedVersionsForConstant.Contains(requestedVersion)) + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(baseUnitItem); } - writer.WriteStartArray("constant"u8); - - if(value is IEnumerable objectListConstant) - { - foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(constantItem); - } - } - writer.WriteEndArray(); - break; - case "definedcategory": - var allowedVersionsForDefinedCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); - if(!allowedVersionsForDefinedCategory.Contains(requestedVersion)) + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(constantItem); } - writer.WriteStartArray("definedCategory"u8); - - if(value is IEnumerable objectListDefinedCategory) - { - foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definedCategoryItem); - } - } - writer.WriteEndArray(); - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("definedCategory"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definedCategoryItem); } - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("fileType"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(fileTypeItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "filetype": - var allowedVersionsForFileType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("glossary"u8); - if(!allowedVersionsForFileType.Contains(requestedVersion)) + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(glossaryItem); } - writer.WriteStartArray("fileType"u8); - - if(value is IEnumerable objectListFileType) - { - foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileTypeItem); - } - } - writer.WriteEndArray(); - break; - case "glossary": - var allowedVersionsForGlossary = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForGlossary.Contains(requestedVersion)) + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("glossary"u8); - - if(value is IEnumerable objectListGlossary) - { - foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(glossaryItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterTypeItem); } - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("referenceSource"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceSourceItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(ruleItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("scale"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(scaleItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(unitItem); } - writer.WriteStartArray("parameterType"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("unitPrefix"u8); - if(value is IEnumerable objectListParameterType) + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) { - foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterTypeItem); - } + writer.WriteStringValue(unitPrefixItem); } - + writer.WriteEndArray(); + break; - case "referencesource": - var allowedVersionsForReferenceSource = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ModelReferenceDataLibrary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForReferenceSource.Contains(requestedVersion)) + foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("referenceSource"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("baseQuantityKind"u8); - if(value is IEnumerable objectListReferenceSource) + foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceSourceItem); - } + writer.WriteOrderedItem(baseQuantityKindItem); } - + writer.WriteEndArray(); - break; - case "requiredrdl": - var allowedVersionsForRequiredRdl = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("baseUnit"u8); - if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(baseUnitItem); } - writer.WritePropertyName("requiredRdl"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); + + foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(constantItem); } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("definedCategory"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definedCategoryItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "rule": - var allowedVersionsForRule = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForRule.Contains(requestedVersion)) + foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("rule"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListRule) + foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(ruleItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("fileType"u8); - if(!allowedVersionsForScale.Contains(requestedVersion)) + foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(fileTypeItem); } - writer.WriteStartArray("scale"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("glossary"u8); - if(value is IEnumerable objectListScale) + foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) { - foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(scaleItem); - } + writer.WriteStringValue(glossaryItem); } - + writer.WriteEndArray(); - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(modelReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(parameterTypeItem); } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("referenceSource"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceSourceItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("requiredRdl"u8); + + if(modelReferenceDataLibrary.RequiredRdl.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); } else { writer.WriteNullValue(); } - break; - case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); - if(!allowedVersionsForUnit.Contains(requestedVersion)) + foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(ruleItem); } - writer.WriteStartArray("unit"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("scale"u8); - if(value is IEnumerable objectListUnit) + foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) { - foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(unitItem); - } + writer.WriteStringValue(scaleItem); } - + writer.WriteEndArray(); - break; - case "unitprefix": - var allowedVersionsForUnitPrefix = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); - if(!allowedVersionsForUnitPrefix.Contains(requestedVersion)) + foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(unitItem); } + writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); - if(value is IEnumerable objectListUnitPrefix) + foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) { - foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(unitPrefixItem); - } + writer.WriteStringValue(unitPrefixItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelReferenceDataLibrary"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ModelReferenceDataLibrary modelReferenceDataLibrary) - { - throw new ArgumentException("The thing shall be a ModelReferenceDataLibrary", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ModelReferenceDataLibrary since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.0.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ModelReferenceDataLibrary for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) @@ -770,6 +423,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) @@ -778,6 +432,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) @@ -786,6 +441,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); writer.WriteStartArray("constant"u8); @@ -796,6 +452,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) @@ -804,6 +461,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) @@ -812,6 +470,25 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) @@ -820,6 +497,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) @@ -828,6 +506,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -836,8 +515,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(modelReferenceDataLibrary.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(modelReferenceDataLibrary.Name); writer.WriteStartArray("parameterType"u8); @@ -848,6 +530,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) @@ -856,6 +539,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); if(modelReferenceDataLibrary.RequiredRdl.HasValue) @@ -877,6 +561,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) @@ -885,8 +570,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) @@ -895,6 +583,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) @@ -903,9 +592,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ModelReferenceDataLibrary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modelReferenceDataLibrary.Actor.HasValue) + { + writer.WriteStringValue(modelReferenceDataLibrary.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) @@ -914,6 +615,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) @@ -922,6 +624,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) @@ -930,6 +633,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); writer.WriteStartArray("constant"u8); @@ -940,6 +644,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) @@ -948,6 +653,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) @@ -956,6 +662,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -964,6 +671,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -972,6 +680,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) @@ -980,6 +689,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) @@ -988,6 +698,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -996,6 +707,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(modelReferenceDataLibrary.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -1010,6 +722,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) @@ -1018,6 +731,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); if(modelReferenceDataLibrary.RequiredRdl.HasValue) @@ -1039,6 +753,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) @@ -1047,8 +762,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); writer.WriteStringValue(modelReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) @@ -1057,6 +775,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) @@ -1065,352 +784,534 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.2.0"); - writer.WriteStartArray("alias"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; } + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + writer.WriteEndArray(); + break; + case "basequantitykind": + if(!AllowedVersionsPerProperty["baseQuantityKind"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("baseQuantityKind"u8); - foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListBaseQuantityKind) { - writer.WriteOrderedItem(baseQuantityKindItem); + foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } } - + writer.WriteEndArray(); + break; + case "baseunit": + if(!AllowedVersionsPerProperty["baseUnit"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("baseUnit"u8); - foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListBaseUnit) { - writer.WriteStringValue(baseUnitItem); + foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); - writer.WriteStartArray("constant"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + break; + case "constant": + if(!AllowedVersionsPerProperty["constant"].Contains(requestedVersion)) { - writer.WriteStringValue(constantItem); + return; } + writer.WriteStartArray("constant"u8); + + if(value is IEnumerable objectListConstant) + { + foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + } + writer.WriteEndArray(); + break; + case "definedcategory": + if(!AllowedVersionsPerProperty["definedCategory"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("definedCategory"u8); - foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinedCategory) { - writer.WriteStringValue(definedCategoryItem); + foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } } - + writer.WriteEndArray(); + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("definition"u8); - foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "filetype": + if(!AllowedVersionsPerProperty["fileType"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("fileType"u8); - foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListFileType) { - writer.WriteStringValue(fileTypeItem); + foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("glossary"u8); - - foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + break; + case "glossary": + if(!AllowedVersionsPerProperty["glossary"].Contains(requestedVersion)) { - writer.WriteStringValue(glossaryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("glossary"u8); - foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGlossary) { - writer.WriteStringValue(hyperLinkItem); + foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelReferenceDataLibrary.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(modelReferenceDataLibrary.Name); - writer.WriteStartArray("parameterType"u8); - - foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterTypeItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referenceSource"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(referenceSourceItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("requiredRdl"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(modelReferenceDataLibrary.RequiredRdl.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); - writer.WriteStartArray("rule"u8); - - foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(ruleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("scale"u8); - - foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(scaleItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); - writer.WriteStartArray("unit"u8); - - foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(unitItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("unitPrefix"u8); - - foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(unitPrefixItem); + return; } - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ModelReferenceDataLibrary for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(modelReferenceDataLibrary.Actor.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(modelReferenceDataLibrary.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in modelReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "parametertype": + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("baseQuantityKind"u8); + writer.WriteStartArray("parameterType"u8); - foreach(var baseQuantityKindItem in modelReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListParameterType) { - writer.WriteOrderedItem(baseQuantityKindItem); + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("baseUnit"u8); - - foreach(var baseUnitItem in modelReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + break; + case "referencesource": + if(!AllowedVersionsPerProperty["referenceSource"].Contains(requestedVersion)) { - writer.WriteStringValue(baseUnitItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ClassKind.ToString()); - writer.WriteStartArray("constant"u8); + writer.WriteStartArray("referenceSource"u8); - foreach(var constantItem in modelReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListReferenceSource) { - writer.WriteStringValue(constantItem); + foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("definedCategory"u8); - - foreach(var definedCategoryItem in modelReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + break; + case "requiredrdl": + if(!AllowedVersionsPerProperty["requiredRdl"].Contains(requestedVersion)) { - writer.WriteStringValue(definedCategoryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in modelReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("requiredRdl"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modelReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modelReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in modelReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(fileTypeItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("glossary"u8); - - foreach(var glossaryItem in modelReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + break; + case "rule": + if(!AllowedVersionsPerProperty["rule"].Contains(requestedVersion)) { - writer.WriteStringValue(glossaryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("rule"u8); - foreach(var hyperLinkItem in modelReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRule) { - writer.WriteStringValue(hyperLinkItem); + foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modelReferenceDataLibrary.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(modelReferenceDataLibrary.Name); - writer.WriteStartArray("parameterType"u8); - - foreach(var parameterTypeItem in modelReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + break; + case "scale": + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterTypeItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referenceSource"u8); + writer.WriteStartArray("scale"u8); - foreach(var referenceSourceItem in modelReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListScale) { - writer.WriteStringValue(referenceSourceItem); + foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("requiredRdl"u8); + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(modelReferenceDataLibrary.RequiredRdl.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(modelReferenceDataLibrary.RequiredRdl.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modelReferenceDataLibrary.RevisionNumber); - writer.WriteStartArray("rule"u8); - - foreach(var ruleItem in modelReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(ruleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("scale"u8); + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var scaleItem in modelReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + break; + case "unit": + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { - writer.WriteStringValue(scaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modelReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); - foreach(var unitItem in modelReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUnit) { - writer.WriteStringValue(unitItem); + foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } } - + writer.WriteEndArray(); + break; + case "unitprefix": + if(!AllowedVersionsPerProperty["unitPrefix"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("unitPrefix"u8); - foreach(var unitPrefixItem in modelReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUnitPrefix) { - writer.WriteStringValue(unitPrefixItem); + foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ModelReferenceDataLibrary"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "baseQuantityKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "baseUnit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "constant", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definedCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fileType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "glossary", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceSource", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "requiredRdl", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "rule", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "unitPrefix", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs index 35e0bb8a7..f2c660d07 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ModellingThingReferenceSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,152 @@ namespace CDP4JsonSerializer /// public class ModellingThingReferenceSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ModellingThingReference modellingThingReference) + { + throw new ArgumentException("The thing shall be a ModellingThingReference", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ModellingThingReference since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ModellingThingReference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ModellingThingReference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modellingThingReference.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ModellingThingReference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(modellingThingReference.Actor.HasValue) + { + writer.WriteStringValue(modellingThingReference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(modellingThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(modellingThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(modellingThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(modellingThingReference.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +203,7 @@ public class ModellingThingReferenceSerializer : BaseThingSerializer, IThingSeri /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +211,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +229,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +247,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +265,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -186,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -211,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencedrevisionnumber": - var allowedVersionsForReferencedRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencedRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencedRevisionNumber"].Contains(requestedVersion)) { return; } @@ -236,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencedthing": - var allowedVersionsForReferencedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencedThing"].Contains(requestedVersion)) { return; } @@ -261,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -286,13 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -315,144 +396,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ModellingThingReference modellingThingReference) - { - throw new ArgumentException("The thing shall be a ModellingThingReference", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ModellingThingReference since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modellingThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(modellingThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modellingThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(modellingThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modellingThingReference.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ModellingThingReference for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(modellingThingReference.Actor.HasValue) - { - writer.WriteStringValue(modellingThingReference.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(modellingThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in modellingThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in modellingThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(modellingThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(modellingThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(modellingThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(modellingThingReference.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(modellingThingReference.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedRevisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs index d00ea6336..b16ada893 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipRuleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,231 +51,500 @@ namespace CDP4JsonSerializer public class MultiRelationshipRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not MultiRelationshipRule multiRelationshipRule) + { + throw new ArgumentException("The thing shall be a MultiRelationshipRule", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationshipRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationshipRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); - if(value is IEnumerable objectListAlias) + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(relatedCategoryItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationshipRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(relatedCategoryItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationshipRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedCategoryItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationshipRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationshipRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(multiRelationshipRule.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(multiRelationshipRule.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationshipRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); + writer.WritePropertyName("maxRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MaxRelated); + writer.WritePropertyName("minRelated"u8); + writer.WriteNumberValue(multiRelationshipRule.MinRelated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationshipRule.Name); + writer.WriteStartArray("relatedCategory"u8); + + foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedCategoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("relationshipCategory"u8); + writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(multiRelationshipRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationshipRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -292,15 +562,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "maxrelated": - var allowedVersionsForMaxRelated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMaxRelated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["maxRelated"].Contains(requestedVersion)) { return; } @@ -318,15 +580,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "minrelated": - var allowedVersionsForMinRelated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMinRelated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["minRelated"].Contains(requestedVersion)) { return; } @@ -344,14 +598,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -369,15 +616,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -395,15 +634,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "relatedcategory": - var allowedVersionsForRelatedCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relatedCategory"].Contains(requestedVersion)) { return; } @@ -421,15 +652,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "relationshipcategory": - var allowedVersionsForRelationshipCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelationshipCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relationshipCategory"].Contains(requestedVersion)) { return; } @@ -447,15 +670,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -473,15 +688,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -499,13 +706,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -528,317 +729,29 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not MultiRelationshipRule multiRelationshipRule) - { - throw new ArgumentException("The thing shall be a MultiRelationshipRule", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationshipRule since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationshipRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); - writer.WritePropertyName("maxRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MaxRelated); - writer.WritePropertyName("minRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MinRelated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationshipRule.Name); - writer.WriteStartArray("relatedCategory"u8); - - foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(multiRelationshipRule.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationshipRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); - writer.WritePropertyName("maxRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MaxRelated); - writer.WritePropertyName("minRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MinRelated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationshipRule.Name); - writer.WriteStartArray("relatedCategory"u8); - - foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(multiRelationshipRule.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationshipRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); - writer.WritePropertyName("maxRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MaxRelated); - writer.WritePropertyName("minRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MinRelated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationshipRule.Name); - writer.WriteStartArray("relatedCategory"u8); - - foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(multiRelationshipRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(multiRelationshipRule.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationshipRule for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(multiRelationshipRule.Actor.HasValue) - { - writer.WriteStringValue(multiRelationshipRule.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in multiRelationshipRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationshipRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in multiRelationshipRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationshipRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationshipRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in multiRelationshipRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationshipRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(multiRelationshipRule.IsDeprecated); - writer.WritePropertyName("maxRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MaxRelated); - writer.WritePropertyName("minRelated"u8); - writer.WriteNumberValue(multiRelationshipRule.MinRelated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationshipRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationshipRule.Name); - writer.WriteStartArray("relatedCategory"u8); - - foreach(var relatedCategoryItem in multiRelationshipRule.RelatedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("relationshipCategory"u8); - writer.WriteStringValue(multiRelationshipRule.RelationshipCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationshipRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(multiRelationshipRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(multiRelationshipRule.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maxRelated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minRelated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "relationshipCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs index fb3357b34..a32f0b238 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/MultiRelationshipSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,260 @@ namespace CDP4JsonSerializer /// public class MultiRelationshipSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not MultiRelationship multiRelationship) + { + throw new ArgumentException("The thing shall be a MultiRelationship", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationship since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationship for Version 1.0.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationship for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationship for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationship.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing MultiRelationship for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(multiRelationship.Actor.HasValue) + { + writer.WriteStringValue(multiRelationship.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(multiRelationship.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(multiRelationship.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(multiRelationship.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(multiRelationship.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(multiRelationship.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(multiRelationship.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +311,7 @@ public class MultiRelationshipSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -112,15 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -138,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,13 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -263,15 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -289,14 +481,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametervalue": - var allowedVersionsForParameterValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterValue"].Contains(requestedVersion)) { return; } @@ -314,15 +499,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { return; } @@ -340,15 +517,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -366,13 +535,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -395,241 +558,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not MultiRelationship multiRelationship) - { - throw new ArgumentException("The thing shall be a MultiRelationship", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of MultiRelationship since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.0.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationship.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationship.Iid); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(multiRelationship.Owner); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationship.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(multiRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationship.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationship.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(multiRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationship.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(multiRelationship.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing MultiRelationship for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(multiRelationship.Actor.HasValue) - { - writer.WriteStringValue(multiRelationship.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in multiRelationship.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(multiRelationship.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in multiRelationship.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in multiRelationship.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(multiRelationship.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(multiRelationship.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(multiRelationship.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(multiRelationship.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in multiRelationship.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in multiRelationship.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(multiRelationship.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(multiRelationship.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs index 6c4ddc067..f609812ee 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NaturalLanguageSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class NaturalLanguageSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not NaturalLanguage naturalLanguage) + { + throw new ArgumentException("The thing shall be a NaturalLanguage", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of NaturalLanguage since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing NaturalLanguage for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing NaturalLanguage for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing NaturalLanguage for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(naturalLanguage.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing NaturalLanguage for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(naturalLanguage.Actor.HasValue) + { + writer.WriteStringValue(naturalLanguage.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(naturalLanguage.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(naturalLanguage.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(naturalLanguage.Name); + writer.WritePropertyName("nativeName"u8); + writer.WriteStringValue(naturalLanguage.NativeName); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(naturalLanguage.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(naturalLanguage.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class NaturalLanguageSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -214,14 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -265,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "nativename": - var allowedVersionsForNativeName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNativeName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["nativeName"].Contains(requestedVersion)) { return; } @@ -291,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not NaturalLanguage naturalLanguage) - { - throw new ArgumentException("The thing shall be a NaturalLanguage", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of NaturalLanguage since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(naturalLanguage.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(naturalLanguage.LanguageCode); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(naturalLanguage.Name); - writer.WritePropertyName("nativeName"u8); - writer.WriteStringValue(naturalLanguage.NativeName); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(naturalLanguage.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(naturalLanguage.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(naturalLanguage.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(naturalLanguage.Name); - writer.WritePropertyName("nativeName"u8); - writer.WriteStringValue(naturalLanguage.NativeName); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(naturalLanguage.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(naturalLanguage.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(naturalLanguage.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(naturalLanguage.Name); - writer.WritePropertyName("nativeName"u8); - writer.WriteStringValue(naturalLanguage.NativeName); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(naturalLanguage.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(naturalLanguage.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing NaturalLanguage for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(naturalLanguage.Actor.HasValue) - { - writer.WriteStringValue(naturalLanguage.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(naturalLanguage.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in naturalLanguage.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in naturalLanguage.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(naturalLanguage.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(naturalLanguage.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(naturalLanguage.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(naturalLanguage.Name); - writer.WritePropertyName("nativeName"u8); - writer.WriteStringValue(naturalLanguage.NativeName); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(naturalLanguage.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(naturalLanguage.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "nativeName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs index 25f580cc5..ec17d25b0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedElementSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,237 @@ namespace CDP4JsonSerializer /// public class NestedElementSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not NestedElement nestedElement) + { + throw new ArgumentException("The thing shall be a NestedElement", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of NestedElement since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing NestedElement for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing NestedElement for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing NestedElement for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedElement.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing NestedElement for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(nestedElement.Actor.HasValue) + { + writer.WriteStringValue(nestedElement.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedElement.ClassKind.ToString()); + writer.WriteStartArray("elementUsage"u8); + + foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(elementUsageItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedElement.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedElement.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("nestedParameter"u8); + + foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedElement.RevisionNumber); + writer.WritePropertyName("rootElement"u8); + writer.WriteStringValue(nestedElement.RootElement); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedElement.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +288,7 @@ public class NestedElementSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "elementusage": - var allowedVersionsForElementUsage = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForElementUsage.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["elementUsage"].Contains(requestedVersion)) { return; } @@ -138,14 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +404,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isvolatile": - var allowedVersionsForIsVolatile = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsVolatile.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isVolatile"].Contains(requestedVersion)) { return; } @@ -240,14 +422,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +440,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "nestedparameter": - var allowedVersionsForNestedParameter = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNestedParameter.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["nestedParameter"].Contains(requestedVersion)) { return; } @@ -291,15 +458,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,15 +476,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "rootelement": - var allowedVersionsForRootElement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRootElement.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["rootElement"].Contains(requestedVersion)) { return; } @@ -343,13 +494,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -372,221 +517,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not NestedElement nestedElement) - { - throw new ArgumentException("The thing shall be a NestedElement", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of NestedElement since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedElement.ClassKind.ToString()); - writer.WriteStartArray("elementUsage"u8); - - foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(elementUsageItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedElement.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedElement.IsVolatile); - writer.WriteStartArray("nestedParameter"u8); - - foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(nestedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedElement.RevisionNumber); - writer.WritePropertyName("rootElement"u8); - writer.WriteStringValue(nestedElement.RootElement); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedElement.ClassKind.ToString()); - writer.WriteStartArray("elementUsage"u8); - - foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(elementUsageItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedElement.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedElement.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("nestedParameter"u8); - - foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(nestedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedElement.RevisionNumber); - writer.WritePropertyName("rootElement"u8); - writer.WriteStringValue(nestedElement.RootElement); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedElement.ClassKind.ToString()); - writer.WriteStartArray("elementUsage"u8); - - foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(elementUsageItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedElement.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedElement.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("nestedParameter"u8); - - foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(nestedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedElement.RevisionNumber); - writer.WritePropertyName("rootElement"u8); - writer.WriteStringValue(nestedElement.RootElement); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(nestedElement.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing NestedElement for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(nestedElement.Actor.HasValue) - { - writer.WriteStringValue(nestedElement.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedElement.ClassKind.ToString()); - writer.WriteStartArray("elementUsage"u8); - - foreach(var elementUsageItem in nestedElement.ElementUsage.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(elementUsageItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedElement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedElement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedElement.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedElement.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedElement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("nestedParameter"u8); - - foreach(var nestedParameterItem in nestedElement.NestedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(nestedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedElement.RevisionNumber); - writer.WritePropertyName("rootElement"u8); - writer.WriteStringValue(nestedElement.RootElement); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(nestedElement.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "elementUsage", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isVolatile", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "nestedParameter", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "rootElement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs index a2599bba9..ead620444 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NestedParameterSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,233 @@ namespace CDP4JsonSerializer /// public class NestedParameterSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not NestedParameter nestedParameter) + { + throw new ArgumentException("The thing shall be a NestedParameter", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of NestedParameter since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing NestedParameter for Version 1.0.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing NestedParameter for Version 1.1.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing NestedParameter for Version 1.2.0"); + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedParameter.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing NestedParameter for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(nestedParameter.Actor.HasValue) + { + writer.WriteStringValue(nestedParameter.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualState"u8); + + if(nestedParameter.ActualState.HasValue) + { + writer.WriteStringValue(nestedParameter.ActualState.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("actualValue"u8); + writer.WriteStringValue(nestedParameter.ActualValue); + writer.WritePropertyName("associatedParameter"u8); + writer.WriteStringValue(nestedParameter.AssociatedParameter); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(nestedParameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("formula"u8); + writer.WriteStringValue(nestedParameter.Formula); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(nestedParameter.Iid); + writer.WritePropertyName("isVolatile"u8); + writer.WriteBooleanValue(nestedParameter.IsVolatile); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(nestedParameter.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(nestedParameter.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(nestedParameter.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +284,7 @@ public class NestedParameterSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +292,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +310,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "actualstate": - var allowedVersionsForActualState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForActualState.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actualState"].Contains(requestedVersion)) { return; } @@ -112,15 +328,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "actualvalue": - var allowedVersionsForActualValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForActualValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actualValue"].Contains(requestedVersion)) { return; } @@ -138,15 +346,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "associatedparameter": - var allowedVersionsForAssociatedParameter = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAssociatedParameter.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["associatedParameter"].Contains(requestedVersion)) { return; } @@ -164,15 +364,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -190,14 +382,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -215,14 +400,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -240,15 +418,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "formula": - var allowedVersionsForFormula = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFormula.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["formula"].Contains(requestedVersion)) { return; } @@ -266,15 +436,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -292,15 +454,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isvolatile": - var allowedVersionsForIsVolatile = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsVolatile.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isVolatile"].Contains(requestedVersion)) { return; } @@ -318,14 +472,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -343,15 +490,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -369,15 +508,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -395,13 +526,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -424,225 +549,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not NestedParameter nestedParameter) - { - throw new ArgumentException("The thing shall be a NestedParameter", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of NestedParameter since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.0.0"); - writer.WritePropertyName("actualState"u8); - - if(nestedParameter.ActualState.HasValue) - { - writer.WriteStringValue(nestedParameter.ActualState.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("actualValue"u8); - writer.WriteStringValue(nestedParameter.ActualValue); - writer.WritePropertyName("associatedParameter"u8); - writer.WriteStringValue(nestedParameter.AssociatedParameter); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedParameter.ClassKind.ToString()); - writer.WritePropertyName("formula"u8); - writer.WriteStringValue(nestedParameter.Formula); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedParameter.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedParameter.IsVolatile); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(nestedParameter.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedParameter.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.1.0"); - writer.WritePropertyName("actualState"u8); - - if(nestedParameter.ActualState.HasValue) - { - writer.WriteStringValue(nestedParameter.ActualState.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("actualValue"u8); - writer.WriteStringValue(nestedParameter.ActualValue); - writer.WritePropertyName("associatedParameter"u8); - writer.WriteStringValue(nestedParameter.AssociatedParameter); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedParameter.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("formula"u8); - writer.WriteStringValue(nestedParameter.Formula); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedParameter.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedParameter.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(nestedParameter.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedParameter.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.2.0"); - writer.WritePropertyName("actualState"u8); - - if(nestedParameter.ActualState.HasValue) - { - writer.WriteStringValue(nestedParameter.ActualState.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("actualValue"u8); - writer.WriteStringValue(nestedParameter.ActualValue); - writer.WritePropertyName("associatedParameter"u8); - writer.WriteStringValue(nestedParameter.AssociatedParameter); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedParameter.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("formula"u8); - writer.WriteStringValue(nestedParameter.Formula); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedParameter.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedParameter.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(nestedParameter.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedParameter.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(nestedParameter.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing NestedParameter for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(nestedParameter.Actor.HasValue) - { - writer.WriteStringValue(nestedParameter.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("actualState"u8); - - if(nestedParameter.ActualState.HasValue) - { - writer.WriteStringValue(nestedParameter.ActualState.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("actualValue"u8); - writer.WriteStringValue(nestedParameter.ActualValue); - writer.WritePropertyName("associatedParameter"u8); - writer.WriteStringValue(nestedParameter.AssociatedParameter); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(nestedParameter.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in nestedParameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in nestedParameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("formula"u8); - writer.WriteStringValue(nestedParameter.Formula); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(nestedParameter.Iid); - writer.WritePropertyName("isVolatile"u8); - writer.WriteBooleanValue(nestedParameter.IsVolatile); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(nestedParameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(nestedParameter.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(nestedParameter.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(nestedParameter.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "actualState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "actualValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "associatedParameter", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "formula", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isVolatile", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs index 46c14ccad..31a6ead32 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/NotExpressionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,157 @@ namespace CDP4JsonSerializer /// public class NotExpressionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not NotExpression notExpression) + { + throw new ArgumentException("The thing shall be a NotExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of NotExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing NotExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing NotExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing NotExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(notExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing NotExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(notExpression.Actor.HasValue) + { + writer.WriteStringValue(notExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(notExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(notExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(notExpression.RevisionNumber); + writer.WritePropertyName("term"u8); + writer.WriteStringValue(notExpression.Term); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(notExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +208,7 @@ public class NotExpressionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +216,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +234,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +252,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +270,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "term": - var allowedVersionsForTerm = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTerm.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["term"].Contains(requestedVersion)) { return; } @@ -265,13 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -294,149 +383,20 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not NotExpression notExpression) - { - throw new ArgumentException("The thing shall be a NotExpression", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of NotExpression since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(notExpression.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(notExpression.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(notExpression.RevisionNumber); - writer.WritePropertyName("term"u8); - writer.WriteStringValue(notExpression.Term); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(notExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(notExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(notExpression.RevisionNumber); - writer.WritePropertyName("term"u8); - writer.WriteStringValue(notExpression.Term); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(notExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(notExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(notExpression.RevisionNumber); - writer.WritePropertyName("term"u8); - writer.WriteStringValue(notExpression.Term); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(notExpression.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing NotExpression for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(notExpression.Actor.HasValue) - { - writer.WriteStringValue(notExpression.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(notExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in notExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in notExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(notExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(notExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(notExpression.RevisionNumber); - writer.WritePropertyName("term"u8); - writer.WriteStringValue(notExpression.Term); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(notExpression.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "term", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs index 2dbb091a5..7090d29fd 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OptionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,369 @@ namespace CDP4JsonSerializer public class OptionSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not Option option) + { + throw new ArgumentException("The thing shall be a Option", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of Option since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Option for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); - if(value is IEnumerable objectListAlias) + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(nestedElementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Option for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); - if(value is IEnumerable objectListDefinition) + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(nestedElementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Option for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); + writer.WriteStartArray("nestedElement"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(nestedElementItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(option.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Option for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(option.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(option.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(option.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "nestedelement": - var allowedVersionsForNestedElement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForNestedElement.Contains(requestedVersion)) + foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(option.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(option.Name); writer.WriteStartArray("nestedElement"u8); - if(value is IEnumerable objectListNestedElement) + foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) { - foreach(var nestedElementItem in objectListNestedElement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(nestedElementItem); - } + writer.WriteStringValue(nestedElementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(option.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(option.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(option.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,49 +421,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -444,323 +475,230 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Option"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Option option) - { - throw new ArgumentException("The thing shall be a Option", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Option since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(option.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(option.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(option.Name); - writer.WriteStartArray("nestedElement"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(nestedElementItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(option.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(option.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(option.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(excludedDomainItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(option.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(option.Name); - writer.WriteStartArray("nestedElement"u8); - - foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(nestedElementItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(option.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(option.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(option.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "nestedelement": + if(!AllowedVersionsPerProperty["nestedElement"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(option.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(option.Name); writer.WriteStartArray("nestedElement"u8); - foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListNestedElement) { - writer.WriteStringValue(nestedElementItem); + foreach(var nestedElementItem in objectListNestedElement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(nestedElementItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(option.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(option.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(option.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Option for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(option.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(option.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in option.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in option.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(option.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in option.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in option.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in option.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in option.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(option.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(option.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(option.Name); - writer.WriteStartArray("nestedElement"u8); - - foreach(var nestedElementItem in option.NestedElement.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(nestedElementItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(option.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(option.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(option.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Option"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "nestedElement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs index 923a18674..5cd8ddfb5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrExpressionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,185 @@ namespace CDP4JsonSerializer /// public class OrExpressionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not OrExpression orExpression) + { + throw new ArgumentException("The thing shall be a OrExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of OrExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing OrExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing OrExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing OrExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(orExpression.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing OrExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(orExpression.Actor.HasValue) + { + writer.WriteStringValue(orExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(orExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(orExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(orExpression.RevisionNumber); + writer.WriteStartArray("term"u8); + + foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(termItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(orExpression.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +236,7 @@ public class OrExpressionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +244,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +298,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +316,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +334,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +352,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +370,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "term": - var allowedVersionsForTerm = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTerm.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["term"].Contains(requestedVersion)) { return; } @@ -265,13 +388,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -294,173 +411,20 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not OrExpression orExpression) - { - throw new ArgumentException("The thing shall be a OrExpression", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of OrExpression since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(orExpression.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(orExpression.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(orExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(orExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(orExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(orExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(orExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(orExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(orExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(orExpression.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing OrExpression for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(orExpression.Actor.HasValue) - { - writer.WriteStringValue(orExpression.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(orExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in orExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in orExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(orExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(orExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(orExpression.RevisionNumber); - writer.WriteStartArray("term"u8); - - foreach(var termItem in orExpression.Term.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(termItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(orExpression.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "term", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs index 621dc57aa..33ee7da57 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrdinalScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,370 +51,449 @@ namespace CDP4JsonSerializer public class OrdinalScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not OrdinalScale ordinalScale) + { + throw new ArgumentException("The thing shall be a OrdinalScale", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of OrdinalScale since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing OrdinalScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListAlias) + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing OrdinalScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing OrdinalScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(mappingToReferenceScaleItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ordinalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing OrdinalScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ordinalScale.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(ordinalScale.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "ismaximuminclusive": - var allowedVersionsForIsMaximumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ordinalScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "isminimuminclusive": - var allowedVersionsForIsMinimumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "mappingtoreferencescale": - var allowedVersionsForMappingToReferenceScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ordinalScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ordinalScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListMappingToReferenceScale) + foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } + writer.WriteStringValue(mappingToReferenceScaleItem); } - + writer.WriteEndArray(); - break; - case "maximumpermissiblevalue": - var allowedVersionsForMaximumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ordinalScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ordinalScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ordinalScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ordinalScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ordinalScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ordinalScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ordinalScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ordinalScale.Unit); + writer.WritePropertyName("useShortNameValues"u8); + writer.WriteBooleanValue(ordinalScale.UseShortNameValues); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - break; - case "minimumpermissiblevalue": - var allowedVersionsForMinimumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -421,50 +501,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,51 +537,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "negativevalueconnotation": - var allowedVersionsForNegativeValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("negativeValueConnotation"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - case "numberset": - var allowedVersionsForNumberSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("numberSet"u8); - + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + if(value != null) { - writer.WriteStringValue(((NumberSetKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -524,21 +627,85 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "positivevalueconnotation": - var allowedVersionsForPositiveValueConnotation = new List + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } - if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + break; + case "ismaximuminclusive": + if(!AllowedVersionsPerProperty["isMaximumInclusive"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("positiveValueConnotation"u8); + writer.WritePropertyName("isMaximumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isminimuminclusive": + if(!AllowedVersionsPerProperty["isMinimumInclusive"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("isMinimumInclusive"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "mappingtoreferencescale": + if(!AllowedVersionsPerProperty["mappingToReferenceScale"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("mappingToReferenceScale"u8); + + if(value is IEnumerable objectListMappingToReferenceScale) + { + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(mappingToReferenceScaleItem); + } + } + + writer.WriteEndArray(); + break; + case "maximumpermissiblevalue": + if(!AllowedVersionsPerProperty["maximumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("maximumPermissibleValue"u8); if(value != null) { @@ -550,16 +717,116 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "minimumpermissiblevalue": + if(!AllowedVersionsPerProperty["minimumPermissibleValue"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("minimumPermissibleValue"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "negativevalueconnotation": + if(!AllowedVersionsPerProperty["negativeValueConnotation"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("negativeValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "numberset": + if(!AllowedVersionsPerProperty["numberSet"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("numberSet"u8); + + if(value != null) + { + writer.WriteStringValue(((NumberSetKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "positivevalueconnotation": + if(!AllowedVersionsPerProperty["positiveValueConnotation"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -577,15 +844,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -603,13 +862,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -627,15 +880,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { return; } @@ -653,15 +898,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "useshortnamevalues": - var allowedVersionsForUseShortNameValues = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUseShortNameValues.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["useShortNameValues"].Contains(requestedVersion)) { return; } @@ -679,15 +916,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valuedefinition": - var allowedVersionsForValueDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { return; } @@ -710,397 +939,36 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not OrdinalScale ordinalScale) - { - throw new ArgumentException("The thing shall be a OrdinalScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of OrdinalScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ordinalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ordinalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ordinalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ordinalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ordinalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ordinalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ordinalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ordinalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ordinalScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ordinalScale.Unit); - writer.WritePropertyName("useShortNameValues"u8); - writer.WriteBooleanValue(ordinalScale.UseShortNameValues); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ordinalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ordinalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ordinalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ordinalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ordinalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ordinalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ordinalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ordinalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ordinalScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ordinalScale.Unit); - writer.WritePropertyName("useShortNameValues"u8); - writer.WriteBooleanValue(ordinalScale.UseShortNameValues); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ordinalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ordinalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ordinalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ordinalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ordinalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ordinalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ordinalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ordinalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ordinalScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ordinalScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ordinalScale.Unit); - writer.WritePropertyName("useShortNameValues"u8); - writer.WriteBooleanValue(ordinalScale.UseShortNameValues); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing OrdinalScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(ordinalScale.Actor.HasValue) - { - writer.WriteStringValue(ordinalScale.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ordinalScale.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ordinalScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ordinalScale.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ordinalScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ordinalScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ordinalScale.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ordinalScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ordinalScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ordinalScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ordinalScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ordinalScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ordinalScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ordinalScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ordinalScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ordinalScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ordinalScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ordinalScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ordinalScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ordinalScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ordinalScale.Unit); - writer.WritePropertyName("useShortNameValues"u8); - writer.WriteBooleanValue(ordinalScale.UseShortNameValues); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ordinalScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueDefinitionItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMaximumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMinimumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "mappingToReferenceScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maximumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minimumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "negativeValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "numberSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "positiveValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "useShortNameValues", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs index 9a6f7b740..5c96221c0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class OrganizationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Organization organization) + { + throw new ArgumentException("The thing shall be a Organization", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Organization since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Organization for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Organization for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Organization for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organization.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Organization for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(organization.Actor.HasValue) + { + writer.WriteStringValue(organization.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organization.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organization.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(organization.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(organization.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organization.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(organization.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organization.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class OrganizationSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -214,14 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -265,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -317,13 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Organization organization) - { - throw new ArgumentException("The thing shall be a Organization", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Organization since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organization.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organization.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(organization.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(organization.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organization.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(organization.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organization.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organization.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(organization.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(organization.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organization.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(organization.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organization.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organization.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(organization.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(organization.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organization.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(organization.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(organization.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Organization for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(organization.Actor.HasValue) - { - writer.WriteStringValue(organization.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organization.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in organization.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in organization.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organization.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(organization.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(organization.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(organization.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organization.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(organization.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(organization.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs index a5664db18..cddea0cef 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OrganizationalParticipantSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,115 @@ namespace CDP4JsonSerializer /// public class OrganizationalParticipantSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not OrganizationalParticipant organizationalParticipant) + { + throw new ArgumentException("The thing shall be a OrganizationalParticipant", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of OrganizationalParticipant since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing OrganizationalParticipant for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organizationalParticipant.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + writer.WriteStringValue(organizationalParticipant.Organization); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organizationalParticipant.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organizationalParticipant.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing OrganizationalParticipant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(organizationalParticipant.Actor.HasValue) + { + writer.WriteStringValue(organizationalParticipant.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(organizationalParticipant.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + writer.WriteStringValue(organizationalParticipant.Organization); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(organizationalParticipant.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(organizationalParticipant.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +166,7 @@ public class OrganizationalParticipantSerializer : BaseThingSerializer, IThingSe /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +174,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,13 +192,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -110,14 +210,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -135,14 +228,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -160,13 +246,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -184,14 +264,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -209,13 +282,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "organization": - var allowedVersionsForOrganization = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOrganization.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["organization"].Contains(requestedVersion)) { return; } @@ -233,13 +300,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -257,13 +318,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -286,109 +341,20 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not OrganizationalParticipant organizationalParticipant) - { - throw new ArgumentException("The thing shall be a OrganizationalParticipant", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.2.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of OrganizationalParticipant since Version is below 1.2.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing OrganizationalParticipant for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organizationalParticipant.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("organization"u8); - writer.WriteStringValue(organizationalParticipant.Organization); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organizationalParticipant.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(organizationalParticipant.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing OrganizationalParticipant for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(organizationalParticipant.Actor.HasValue) - { - writer.WriteStringValue(organizationalParticipant.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(organizationalParticipant.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in organizationalParticipant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in organizationalParticipant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(organizationalParticipant.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(organizationalParticipant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("organization"u8); - writer.WriteStringValue(organizationalParticipant.Organization); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(organizationalParticipant.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(organizationalParticipant.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "organization", new []{ "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs index ceb911321..a85d891e5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/OwnedStyleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,597 +51,195 @@ namespace CDP4JsonSerializer public class OwnedStyleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not OwnedStyle ownedStyle) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a OwnedStyle", nameof(thing)); + } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of OwnedStyle since Version is below 1.1.0"); + return; + } - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing OwnedStyle for Version 1.1.0"); writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(ownedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in ownedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "fillcolor": - var allowedVersionsForFillColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFillColor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("fillColor"u8); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "fillopacity": - var allowedVersionsForFillOpacity = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForFillOpacity.Contains(requestedVersion)) + foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("fillOpacity"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((float)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "fontbold": - var allowedVersionsForFontBold = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontBold.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fillColor"u8); - writer.WritePropertyName("fontBold"u8); - - if(value != null) + if(ownedStyle.FillColor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(ownedStyle.FillColor.Value); } else { writer.WriteNullValue(); } - break; - case "fontcolor": - var allowedVersionsForFontColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontColor.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fillOpacity"u8); - writer.WritePropertyName("fontColor"u8); - - if(value != null) + if(ownedStyle.FillOpacity.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteNumberValue(ownedStyle.FillOpacity.Value); } else { writer.WriteNullValue(); } - break; - case "fontitalic": - var allowedVersionsForFontItalic = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontItalic.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontBold"u8); - writer.WritePropertyName("fontItalic"u8); - - if(value != null) + if(ownedStyle.FontBold.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteBooleanValue(ownedStyle.FontBold.Value); } else { writer.WriteNullValue(); } - break; - case "fontname": - var allowedVersionsForFontName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontName.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontColor"u8); - writer.WritePropertyName("fontName"u8); - - if(value != null) + if(ownedStyle.FontColor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(ownedStyle.FontColor.Value); } else { writer.WriteNullValue(); } - break; - case "fontsize": - var allowedVersionsForFontSize = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontSize.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontItalic"u8); - writer.WritePropertyName("fontSize"u8); - - if(value != null) + if(ownedStyle.FontItalic.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteBooleanValue(ownedStyle.FontItalic.Value); } else { writer.WriteNullValue(); } - break; - case "fontstrokethrough": - var allowedVersionsForFontStrokeThrough = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontStrokeThrough.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(ownedStyle.FontName); + writer.WritePropertyName("fontSize"u8); - writer.WritePropertyName("fontStrokeThrough"u8); - - if(value != null) + if(ownedStyle.FontSize.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteNumberValue(ownedStyle.FontSize.Value); } else { writer.WriteNullValue(); } - break; - case "fontunderline": - var allowedVersionsForFontUnderline = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontUnderline.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontStrokeThrough"u8); - writer.WritePropertyName("fontUnderline"u8); - - if(value != null) + if(ownedStyle.FontStrokeThrough.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteBooleanValue(ownedStyle.FontStrokeThrough.Value); } else { writer.WriteNullValue(); } - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontUnderline"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(ownedStyle.FontUnderline.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ownedStyle.Iid); writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(ownedStyle.Name); writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "strokecolor": - var allowedVersionsForStrokeColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeColor.Contains(requestedVersion)) - { - return; - } - + writer.WriteNumberValue(ownedStyle.RevisionNumber); writer.WritePropertyName("strokeColor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "strokeopacity": - var allowedVersionsForStrokeOpacity = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeOpacity.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("strokeOpacity"u8); - - if(value != null) + if(ownedStyle.StrokeColor.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteStringValue(ownedStyle.StrokeColor.Value); } else { writer.WriteNullValue(); } - break; - case "strokewidth": - var allowedVersionsForStrokeWidth = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeWidth.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("strokeOpacity"u8); - writer.WritePropertyName("strokeWidth"u8); - - if(value != null) + if(ownedStyle.StrokeOpacity.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); } else { writer.WriteNullValue(); } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("strokeWidth"u8); - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + if(ownedStyle.StrokeWidth.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); } else { writer.WriteNullValue(); } - break; - case "usedcolor": - var allowedVersionsForUsedColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUsedColor.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("usedColor"u8); - if(value is IEnumerable objectListUsedColor) + foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) { - foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(usedColorItem); - } + writer.WriteStringValue(usedColorItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the OwnedStyle"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not OwnedStyle ownedStyle) - { - throw new ArgumentException("The thing shall be a OwnedStyle", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of OwnedStyle since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing OwnedStyle for Version 1.2.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(ownedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -651,6 +250,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -659,6 +259,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); if(ownedStyle.FillColor.HasValue) @@ -790,6 +391,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ownedStyle.ThingPreference); writer.WriteStartArray("usedColor"u8); foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) @@ -798,9 +401,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing OwnedStyle for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ownedStyle.Actor.HasValue) + { + writer.WriteStringValue(ownedStyle.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(ownedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -811,6 +426,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -819,6 +435,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); if(ownedStyle.FillColor.HasValue) @@ -902,244 +519,516 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM if(ownedStyle.FontUnderline.HasValue) { - writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ownedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ownedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ownedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(ownedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(ownedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(ownedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(ownedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ownedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "fillcolor": + if(!AllowedVersionsPerProperty["fillColor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ownedStyle.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ownedStyle.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ownedStyle.RevisionNumber); - writer.WritePropertyName("strokeColor"u8); + break; + case "fillopacity": + if(!AllowedVersionsPerProperty["fillOpacity"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeColor.HasValue) + writer.WritePropertyName("fillOpacity"u8); + + if(value != null) { - writer.WriteStringValue(ownedStyle.StrokeColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeOpacity"u8); + break; + case "fontbold": + if(!AllowedVersionsPerProperty["fontBold"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeOpacity.HasValue) + writer.WritePropertyName("fontBold"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeWidth"u8); + break; + case "fontcolor": + if(!AllowedVersionsPerProperty["fontColor"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeWidth.HasValue) + writer.WritePropertyName("fontColor"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ownedStyle.ThingPreference); - writer.WriteStartArray("usedColor"u8); - - foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + break; + case "fontitalic": + if(!AllowedVersionsPerProperty["fontItalic"].Contains(requestedVersion)) { - writer.WriteStringValue(usedColorItem); + return; } - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing OwnedStyle for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(ownedStyle.Actor.HasValue) + writer.WritePropertyName("fontItalic"u8); + + if(value != null) { - writer.WriteStringValue(ownedStyle.Actor.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ownedStyle.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ownedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "fontname": + if(!AllowedVersionsPerProperty["fontName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ownedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("fontName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("fillColor"u8); + break; + case "fontsize": + if(!AllowedVersionsPerProperty["fontSize"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FillColor.HasValue) + writer.WritePropertyName("fontSize"u8); + + if(value != null) { - writer.WriteStringValue(ownedStyle.FillColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fillOpacity"u8); + break; + case "fontstrokethrough": + if(!AllowedVersionsPerProperty["fontStrokeThrough"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FillOpacity.HasValue) + writer.WritePropertyName("fontStrokeThrough"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.FillOpacity.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontBold"u8); + break; + case "fontunderline": + if(!AllowedVersionsPerProperty["fontUnderline"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontBold.HasValue) + writer.WritePropertyName("fontUnderline"u8); + + if(value != null) { - writer.WriteBooleanValue(ownedStyle.FontBold.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontColor"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontColor.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(ownedStyle.FontColor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontItalic"u8); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontItalic.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteBooleanValue(ownedStyle.FontItalic.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontName"u8); - writer.WriteStringValue(ownedStyle.FontName); - writer.WritePropertyName("fontSize"u8); + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontSize.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.FontSize.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontStrokeThrough"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontStrokeThrough.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteBooleanValue(ownedStyle.FontStrokeThrough.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontUnderline"u8); + break; + case "strokecolor": + if(!AllowedVersionsPerProperty["strokeColor"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.FontUnderline.HasValue) + writer.WritePropertyName("strokeColor"u8); + + if(value != null) { - writer.WriteBooleanValue(ownedStyle.FontUnderline.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ownedStyle.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ownedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ownedStyle.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ownedStyle.RevisionNumber); - writer.WritePropertyName("strokeColor"u8); + break; + case "strokeopacity": + if(!AllowedVersionsPerProperty["strokeOpacity"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeColor.HasValue) + writer.WritePropertyName("strokeOpacity"u8); + + if(value != null) { - writer.WriteStringValue(ownedStyle.StrokeColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeOpacity"u8); + break; + case "strokewidth": + if(!AllowedVersionsPerProperty["strokeWidth"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeOpacity.HasValue) + writer.WritePropertyName("strokeWidth"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.StrokeOpacity.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeWidth"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(ownedStyle.StrokeWidth.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteNumberValue(ownedStyle.StrokeWidth.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ownedStyle.ThingPreference); + break; + case "usedcolor": + if(!AllowedVersionsPerProperty["usedColor"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("usedColor"u8); - foreach(var usedColorItem in ownedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUsedColor) { - writer.WriteStringValue(usedColorItem); + foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the OwnedStyle"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fillColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fillOpacity", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontBold", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontItalic", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontSize", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontStrokeThrough", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontUnderline", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeOpacity", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeWidth", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "usedColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs index cef6bb6db..d2820f39d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PageSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,218 @@ namespace CDP4JsonSerializer /// public class PageSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Page page) + { + throw new ArgumentException("The thing shall be a Page", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Page since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Page for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Page for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(page.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Page for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(page.Actor.HasValue) + { + writer.WriteStringValue(page.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(page.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(page.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(page.Name); + writer.WriteStartArray("note"u8); + + foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(noteItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(page.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(page.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(page.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(page.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +269,7 @@ public class PageSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +277,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +295,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -111,14 +313,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +331,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -161,14 +349,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -186,14 +367,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -211,14 +385,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -236,14 +403,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -261,14 +421,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -286,14 +439,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "note": - var allowedVersionsForNote = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNote.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["note"].Contains(requestedVersion)) { return; } @@ -311,14 +457,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -336,14 +475,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,14 +493,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +511,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,204 +534,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Page page) - { - throw new ArgumentException("The thing shall be a Page", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Page since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(page.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(page.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(page.Name); - writer.WriteStartArray("note"u8); - - foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(noteItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(page.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(page.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(page.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(page.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(page.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(page.Name); - writer.WriteStartArray("note"u8); - - foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(noteItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(page.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(page.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(page.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(page.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Page for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(page.Actor.HasValue) - { - writer.WriteStringValue(page.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in page.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(page.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(page.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in page.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in page.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(page.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(page.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(page.Name); - writer.WriteStartArray("note"u8); - - foreach(var noteItem in page.Note.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(noteItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(page.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(page.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(page.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(page.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "note", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs index d2bb26180..81f5146b0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterGroupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,201 @@ namespace CDP4JsonSerializer /// public class ParameterGroupSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterGroup parameterGroup) + { + throw new ArgumentException("The thing shall be a ParameterGroup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterGroup since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterGroup for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterGroup for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterGroup for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterGroup.Actor.HasValue) + { + writer.WriteStringValue(parameterGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterGroup.ClassKind.ToString()); + writer.WritePropertyName("containingGroup"u8); + + if(parameterGroup.ContainingGroup.HasValue) + { + writer.WriteStringValue(parameterGroup.ContainingGroup.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterGroup.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +252,7 @@ public class ParameterGroupSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "containinggroup": - var allowedVersionsForContainingGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContainingGroup.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["containingGroup"].Contains(requestedVersion)) { return; } @@ -138,14 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -265,15 +404,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +422,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -320,193 +445,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterGroup parameterGroup) - { - throw new ArgumentException("The thing shall be a ParameterGroup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterGroup since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterGroup.ClassKind.ToString()); - writer.WritePropertyName("containingGroup"u8); - - if(parameterGroup.ContainingGroup.HasValue) - { - writer.WriteStringValue(parameterGroup.ContainingGroup.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterGroup.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterGroup.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterGroup.ClassKind.ToString()); - writer.WritePropertyName("containingGroup"u8); - - if(parameterGroup.ContainingGroup.HasValue) - { - writer.WriteStringValue(parameterGroup.ContainingGroup.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterGroup.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterGroup.ClassKind.ToString()); - writer.WritePropertyName("containingGroup"u8); - - if(parameterGroup.ContainingGroup.HasValue) - { - writer.WriteStringValue(parameterGroup.ContainingGroup.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterGroup.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterGroup.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterGroup for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterGroup.Actor.HasValue) - { - writer.WriteStringValue(parameterGroup.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterGroup.ClassKind.ToString()); - writer.WritePropertyName("containingGroup"u8); - - if(parameterGroup.ContainingGroup.HasValue) - { - writer.WriteStringValue(parameterGroup.ContainingGroup.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterGroup.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterGroup.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "containingGroup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs index 7746b5d07..c3be67cda 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,237 @@ namespace CDP4JsonSerializer /// public class ParameterOverrideSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterOverride parameterOverride) + { + throw new ArgumentException("The thing shall be a ParameterOverride", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverride since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverride for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverride for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverride for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverride.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverride for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterOverride.Actor.HasValue) + { + writer.WriteStringValue(parameterOverride.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverride.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverride.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterOverride.Owner); + writer.WritePropertyName("parameter"u8); + writer.WriteStringValue(parameterOverride.Parameter); + writer.WriteStartArray("parameterSubscription"u8); + + foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverride.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverride.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +288,7 @@ public class ParameterOverrideSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +404,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -239,15 +422,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parameter": - var allowedVersionsForParameter = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameter.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameter"].Contains(requestedVersion)) { return; } @@ -265,15 +440,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametersubscription": - var allowedVersionsForParameterSubscription = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterSubscription.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterSubscription"].Contains(requestedVersion)) { return; } @@ -291,15 +458,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +476,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -341,15 +494,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valueset": - var allowedVersionsForValueSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueSet.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueSet"].Contains(requestedVersion)) { return; } @@ -372,221 +517,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterOverride parameterOverride) - { - throw new ArgumentException("The thing shall be a ParameterOverride", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverride since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverride.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverride.Iid); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterOverride.Owner); - writer.WritePropertyName("parameter"u8); - writer.WriteStringValue(parameterOverride.Parameter); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterSubscriptionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverride.RevisionNumber); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverride.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverride.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterOverride.Owner); - writer.WritePropertyName("parameter"u8); - writer.WriteStringValue(parameterOverride.Parameter); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterSubscriptionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverride.RevisionNumber); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverride.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverride.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterOverride.Owner); - writer.WritePropertyName("parameter"u8); - writer.WriteStringValue(parameterOverride.Parameter); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterSubscriptionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverride.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterOverride.ThingPreference); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverride for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterOverride.Actor.HasValue) - { - writer.WriteStringValue(parameterOverride.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverride.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverride.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverride.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverride.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverride.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterOverride.Owner); - writer.WritePropertyName("parameter"u8); - writer.WriteStringValue(parameterOverride.Parameter); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameterOverride.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterSubscriptionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverride.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterOverride.ThingPreference); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterOverride.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameter", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterSubscription", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs index 2cfd1c470..1c3b80807 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterOverrideValueSetSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,185 @@ namespace CDP4JsonSerializer /// public class ParameterOverrideValueSetSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterOverrideValueSet parameterOverrideValueSet) + { + throw new ArgumentException("The thing shall be a ParameterOverrideValueSet", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverrideValueSet since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverrideValueSet for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverrideValueSet for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverrideValueSet for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterOverrideValueSet for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterOverrideValueSet.Actor.HasValue) + { + writer.WriteStringValue(parameterOverrideValueSet.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); + writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterOverrideValueSet.Iid); + writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterValueSet"u8); + writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); + writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); + writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +236,7 @@ public class ParameterOverrideValueSetSerializer : BaseThingSerializer, IThingSe /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +244,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "computed": - var allowedVersionsForComputed = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForComputed.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["computed"].Contains(requestedVersion)) { return; } @@ -128,14 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("computed"u8, ((ValueArray)value).ToJsonString()); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -153,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -178,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "formula": - var allowedVersionsForFormula = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFormula.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["formula"].Contains(requestedVersion)) { return; } @@ -194,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("formula"u8, ((ValueArray)value).ToJsonString()); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -220,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "manual": - var allowedVersionsForManual = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForManual.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["manual"].Contains(requestedVersion)) { return; } @@ -236,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -261,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametervalueset": - var allowedVersionsForParameterValueSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValueSet.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterValueSet"].Contains(requestedVersion)) { return; } @@ -287,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "published": - var allowedVersionsForPublished = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPublished.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["published"].Contains(requestedVersion)) { return; } @@ -303,15 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("published"u8, ((ValueArray)value).ToJsonString()); break; case "reference": - var allowedVersionsForReference = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["reference"].Contains(requestedVersion)) { return; } @@ -319,15 +410,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("reference"u8, ((ValueArray)value).ToJsonString()); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -345,13 +428,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -369,15 +446,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valueswitch": - var allowedVersionsForValueSwitch = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueSwitch"].Contains(requestedVersion)) { return; } @@ -400,177 +469,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterOverrideValueSet parameterOverrideValueSet) - { - throw new ArgumentException("The thing shall be a ParameterOverrideValueSet", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterOverrideValueSet since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); - writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); - writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverrideValueSet.Iid); - writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); - writer.WritePropertyName("parameterValueSet"u8); - writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); - writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); - writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); - writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverrideValueSet.Iid); - writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterValueSet"u8); - writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); - writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); - writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); - writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverrideValueSet.Iid); - writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterValueSet"u8); - writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); - writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); - writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterOverrideValueSet for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterOverrideValueSet.Actor.HasValue) - { - writer.WriteStringValue(parameterOverrideValueSet.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterOverrideValueSet.ClassKind.ToString()); - writer.WriteString("computed"u8, parameterOverrideValueSet.Computed.ToJsonString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterOverrideValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterOverrideValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteString("formula"u8, parameterOverrideValueSet.Formula.ToJsonString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterOverrideValueSet.Iid); - writer.WriteString("manual"u8, parameterOverrideValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterOverrideValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterValueSet"u8); - writer.WriteStringValue(parameterOverrideValueSet.ParameterValueSet); - writer.WriteString("published"u8, parameterOverrideValueSet.Published.ToJsonString()); - writer.WriteString("reference"u8, parameterOverrideValueSet.Reference.ToJsonString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterOverrideValueSet.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterOverrideValueSet.ThingPreference); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterOverrideValueSet.ValueSwitch.ToString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "computed", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "formula", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "manual", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValueSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "published", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "reference", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSwitch", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs index e9929f62a..edb35c055 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,540 +51,236 @@ namespace CDP4JsonSerializer public class ParameterSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not Parameter parameter) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a Parameter", nameof(thing)); + } - break; - case "allowdifferentownerofoverride": - var allowedVersionsForAllowDifferentOwnerOfOverride = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Parameter since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAllowDifferentOwnerOfOverride.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Parameter for Version 1.0.0"); writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); writer.WritePropertyName("classKind"u8); - - if(value != null) + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(parameter.Group.Value); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); + writer.WriteStartArray("parameterSubscription"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterSubscriptionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "expectsoverride": - var allowedVersionsForExpectsOverride = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExpectsOverride.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); + writer.WritePropertyName("requestedBy"u8); - writer.WritePropertyName("expectsOverride"u8); - - if(value != null) + if(parameter.RequestedBy.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(parameter.RequestedBy.Value); } else { writer.WriteNullValue(); } - break; - case "group": - var allowedVersionsForGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForGroup.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); - writer.WritePropertyName("group"u8); - - if(value != null) + if(parameter.Scale.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(parameter.Scale.Value); } else { writer.WriteNullValue(); } - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("stateDependence"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(parameter.StateDependence.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(parameter.StateDependence.Value); } else { writer.WriteNullValue(); } - break; - case "isoptiondependent": - var allowedVersionsForIsOptionDependent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("valueSet"u8); - if(!allowedVersionsForIsOptionDependent.Contains(requestedVersion)) + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueSetItem); } - writer.WritePropertyName("isOptionDependent"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Parameter for Version 1.1.0"); + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("owner"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("expectsOverride"u8); + writer.WriteBooleanValue(parameter.ExpectsOverride); + writer.WritePropertyName("group"u8); + + if(parameter.Group.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(parameter.Group.Value); } else { writer.WriteNullValue(); } - break; - case "parametersubscription": - var allowedVersionsForParameterSubscription = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterSubscription.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameter.Iid); + writer.WritePropertyName("isOptionDependent"u8); + writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameter.Owner); writer.WriteStartArray("parameterSubscription"u8); - if(value is IEnumerable objectListParameterSubscription) - { - foreach(var parameterSubscriptionItem in objectListParameterSubscription.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterSubscriptionItem); - } - } - - writer.WriteEndArray(); - break; - case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterSubscriptionItem); } - writer.WritePropertyName("parameterType"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "requestedby": - var allowedVersionsForRequestedBy = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRequestedBy.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameter.ParameterType); writer.WritePropertyName("requestedBy"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) + if(parameter.RequestedBy.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(parameter.RequestedBy.Value); } else { writer.WriteNullValue(); } - break; - case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); writer.WritePropertyName("scale"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "statedependence": - var allowedVersionsForStateDependence = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStateDependence.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("stateDependence"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + if(parameter.Scale.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(parameter.Scale.Value); } else { writer.WriteNullValue(); } - break; - case "valueset": - var allowedVersionsForValueSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("stateDependence"u8); - if(!allowedVersionsForValueSet.Contains(requestedVersion)) + if(parameter.StateDependence.HasValue) { - return; + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); } writer.WriteStartArray("valueSet"u8); - if(value is IEnumerable objectListValueSet) + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) { - foreach(var valueSetItem in objectListValueSet.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } + writer.WriteStringValue(valueSetItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Parameter"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Parameter parameter) - { - throw new ArgumentException("The thing shall be a Parameter", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Parameter since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.0.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Parameter for Version 1.2.0"); writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(parameter.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("expectsOverride"u8); writer.WriteBooleanValue(parameter.ExpectsOverride); writer.WritePropertyName("group"u8); @@ -601,6 +298,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(parameter.Iid); writer.WritePropertyName("isOptionDependent"u8); writer.WriteBooleanValue(parameter.IsOptionDependent); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("owner"u8); writer.WriteStringValue(parameter.Owner); writer.WriteStartArray("parameterSubscription"u8); @@ -611,6 +310,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); writer.WriteStringValue(parameter.ParameterType); writer.WritePropertyName("requestedBy"u8); @@ -648,6 +348,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameter.ThingPreference); writer.WriteStartArray("valueSet"u8); foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) @@ -656,9 +358,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Parameter for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameter.Actor.HasValue) + { + writer.WriteStringValue(parameter.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); writer.WritePropertyName("classKind"u8); @@ -671,6 +385,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -679,6 +394,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("expectsOverride"u8); writer.WriteBooleanValue(parameter.ExpectsOverride); writer.WritePropertyName("group"u8); @@ -708,6 +424,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("parameterType"u8); writer.WriteStringValue(parameter.ParameterType); writer.WritePropertyName("requestedBy"u8); @@ -721,254 +438,435 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameter.RevisionNumber); - writer.WritePropertyName("scale"u8); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameter.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameter.Scale.HasValue) + { + writer.WriteStringValue(parameter.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("stateDependence"u8); + + if(parameter.StateDependence.HasValue) + { + writer.WriteStringValue(parameter.StateDependence.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameter.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "allowdifferentownerofoverride": + if(!AllowedVersionsPerProperty["allowDifferentOwnerOfOverride"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "expectsoverride": + if(!AllowedVersionsPerProperty["expectsOverride"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("expectsOverride"u8); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "group": + if(!AllowedVersionsPerProperty["group"].Contains(requestedVersion)) + { + return; + } - if(parameter.Scale.HasValue) + writer.WritePropertyName("group"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Scale.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("stateDependence"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(parameter.StateDependence.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(parameter.StateDependence.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.2.0"); - writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); - writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameter.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + case "isoptiondependent": + if(!AllowedVersionsPerProperty["isOptionDependent"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("expectsOverride"u8); - writer.WriteBooleanValue(parameter.ExpectsOverride); - writer.WritePropertyName("group"u8); - - if(parameter.Group.HasValue) + writer.WritePropertyName("isOptionDependent"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Group.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameter.Iid); - writer.WritePropertyName("isOptionDependent"u8); - writer.WriteBooleanValue(parameter.IsOptionDependent); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameter.Owner); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterSubscriptionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameter.ParameterType); - writer.WritePropertyName("requestedBy"u8); - - if(parameter.RequestedBy.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(parameter.RequestedBy.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameter.RevisionNumber); - writer.WritePropertyName("scale"u8); + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) + { + return; + } - if(parameter.Scale.HasValue) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Scale.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("stateDependence"u8); - - if(parameter.StateDependence.HasValue) - { - writer.WriteStringValue(parameter.StateDependence.Value); - } - else + break; + case "parametersubscription": + if(!AllowedVersionsPerProperty["parameterSubscription"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameter.ThingPreference); - writer.WriteStartArray("valueSet"u8); + writer.WriteStartArray("parameterSubscription"u8); - foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterSubscription) { - writer.WriteStringValue(valueSetItem); + foreach(var parameterSubscriptionItem in objectListParameterSubscription.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterSubscriptionItem); + } } - + writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Parameter for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "parametertype": + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) + { + return; + } - if(parameter.Actor.HasValue) + writer.WritePropertyName("parameterType"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("allowDifferentOwnerOfOverride"u8); - writer.WriteBooleanValue(parameter.AllowDifferentOwnerOfOverride); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameter.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameter.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "requestedby": + if(!AllowedVersionsPerProperty["requestedBy"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameter.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("requestedBy"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("expectsOverride"u8); - writer.WriteBooleanValue(parameter.ExpectsOverride); - writer.WritePropertyName("group"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(parameter.Group.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Group.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameter.Iid); - writer.WritePropertyName("isOptionDependent"u8); - writer.WriteBooleanValue(parameter.IsOptionDependent); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameter.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameter.Owner); - writer.WriteStartArray("parameterSubscription"u8); - - foreach(var parameterSubscriptionItem in parameter.ParameterSubscription.OrderBy(x => x, this.GuidComparer)) + break; + case "scale": + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterSubscriptionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameter.ParameterType); - writer.WritePropertyName("requestedBy"u8); - - if(parameter.RequestedBy.HasValue) + writer.WritePropertyName("scale"u8); + + if(value != null) { - writer.WriteStringValue(parameter.RequestedBy.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameter.RevisionNumber); - writer.WritePropertyName("scale"u8); + break; + case "statedependence": + if(!AllowedVersionsPerProperty["stateDependence"].Contains(requestedVersion)) + { + return; + } - if(parameter.Scale.HasValue) + writer.WritePropertyName("stateDependence"u8); + + if(value != null) { - writer.WriteStringValue(parameter.Scale.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("stateDependence"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(parameter.StateDependence.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(parameter.StateDependence.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameter.ThingPreference); + break; + case "valueset": + if(!AllowedVersionsPerProperty["valueSet"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("valueSet"u8); - foreach(var valueSetItem in parameter.ValueSet.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListValueSet) { - writer.WriteStringValue(valueSetItem); + foreach(var valueSetItem in objectListValueSet.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Parameter"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "allowDifferentOwnerOfOverride", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "expectsOverride", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "group", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isOptionDependent", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterSubscription", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "requestedBy", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "stateDependence", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs index 31ec83387..6832b54a2 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,193 @@ namespace CDP4JsonSerializer /// public class ParameterSubscriptionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterSubscription parameterSubscription) + { + throw new ArgumentException("The thing shall be a ParameterSubscription", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscription since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscription for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscription for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscription for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscription.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscription for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterSubscription.Actor.HasValue) + { + writer.WriteStringValue(parameterSubscription.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscription.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(parameterSubscription.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscription.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscription.ThingPreference); + writer.WriteStartArray("valueSet"u8); + + foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueSetItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +244,7 @@ public class ParameterSubscriptionSerializer : BaseThingSerializer, IThingSerial /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +252,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +270,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -239,15 +378,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -265,13 +396,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -289,15 +414,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valueset": - var allowedVersionsForValueSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueSet.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueSet"].Contains(requestedVersion)) { return; } @@ -320,181 +437,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterSubscription parameterSubscription) - { - throw new ArgumentException("The thing shall be a ParameterSubscription", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscription since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscription.Iid); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterSubscription.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscription.RevisionNumber); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscription.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterSubscription.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscription.RevisionNumber); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscription.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterSubscription.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscription.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterSubscription.ThingPreference); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscription for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterSubscription.Actor.HasValue) - { - writer.WriteStringValue(parameterSubscription.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscription.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscription.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscription.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscription.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscription.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(parameterSubscription.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscription.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterSubscription.ThingPreference); - writer.WriteStartArray("valueSet"u8); - - foreach(var valueSetItem in parameterSubscription.ValueSet.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueSetItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs index 3234ca5c1..41371a9c3 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterSubscriptionValueSetSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,169 @@ namespace CDP4JsonSerializer /// public class ParameterSubscriptionValueSetSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterSubscriptionValueSet parameterSubscriptionValueSet) + { + throw new ArgumentException("The thing shall be a ParameterSubscriptionValueSet", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscriptionValueSet since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscriptionValueSet for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscriptionValueSet for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscriptionValueSet for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterSubscriptionValueSet for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterSubscriptionValueSet.Actor.HasValue) + { + writer.WriteStringValue(parameterSubscriptionValueSet.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.Iid); + writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); + writer.WritePropertyName("subscribedValueSet"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); + writer.WritePropertyName("valueSwitch"u8); + writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +220,7 @@ public class ParameterSubscriptionValueSetSerializer : BaseThingSerializer, IThi /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +228,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +246,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +264,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +282,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +300,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,15 +318,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "manual": - var allowedVersionsForManual = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForManual.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["manual"].Contains(requestedVersion)) { return; } @@ -204,14 +326,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -229,15 +344,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -255,15 +362,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "subscribedvalueset": - var allowedVersionsForSubscribedValueSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSubscribedValueSet.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["subscribedValueSet"].Contains(requestedVersion)) { return; } @@ -281,13 +380,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -305,15 +398,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "valueswitch": - var allowedVersionsForValueSwitch = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["valueSwitch"].Contains(requestedVersion)) { return; } @@ -336,161 +421,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterSubscriptionValueSet parameterSubscriptionValueSet) - { - throw new ArgumentException("The thing shall be a ParameterSubscriptionValueSet", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterSubscriptionValueSet since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.Iid); - writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); - writer.WritePropertyName("subscribedValueSet"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.Iid); - writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); - writer.WritePropertyName("subscribedValueSet"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.Iid); - writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); - writer.WritePropertyName("subscribedValueSet"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterSubscriptionValueSet for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterSubscriptionValueSet.Actor.HasValue) - { - writer.WriteStringValue(parameterSubscriptionValueSet.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterSubscriptionValueSet.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterSubscriptionValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.Iid); - writer.WriteString("manual"u8, parameterSubscriptionValueSet.Manual.ToJsonString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterSubscriptionValueSet.RevisionNumber); - writer.WritePropertyName("subscribedValueSet"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.SubscribedValueSet); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ThingPreference); - writer.WritePropertyName("valueSwitch"u8); - writer.WriteStringValue(parameterSubscriptionValueSet.ValueSwitch.ToString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "manual", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "subscribedValueSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSwitch", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs index 173e8bc3a..2c5253535 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterTypeComponentSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,209 @@ namespace CDP4JsonSerializer /// public class ParameterTypeComponentSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParameterTypeComponent parameterTypeComponent) + { + throw new ArgumentException("The thing shall be a ParameterTypeComponent", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterTypeComponent since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterTypeComponent for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterTypeComponent for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterTypeComponent for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterTypeComponent.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterTypeComponent for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterTypeComponent.Actor.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterTypeComponent.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(parameterTypeComponent.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(parameterTypeComponent.Scale.HasValue) + { + writer.WriteStringValue(parameterTypeComponent.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterTypeComponent.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterTypeComponent.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +260,7 @@ public class ParameterTypeComponentSerializer : BaseThingSerializer, IThingSeria /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -239,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -265,15 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -291,15 +430,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -317,13 +448,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,201 +471,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParameterTypeComponent parameterTypeComponent) - { - throw new ArgumentException("The thing shall be a ParameterTypeComponent", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterTypeComponent since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterTypeComponent.Iid); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameterTypeComponent.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(parameterTypeComponent.Scale.HasValue) - { - writer.WriteStringValue(parameterTypeComponent.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterTypeComponent.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterTypeComponent.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameterTypeComponent.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(parameterTypeComponent.Scale.HasValue) - { - writer.WriteStringValue(parameterTypeComponent.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterTypeComponent.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterTypeComponent.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameterTypeComponent.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(parameterTypeComponent.Scale.HasValue) - { - writer.WriteStringValue(parameterTypeComponent.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterTypeComponent.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterTypeComponent.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterTypeComponent for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(parameterTypeComponent.Actor.HasValue) - { - writer.WriteStringValue(parameterTypeComponent.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterTypeComponent.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterTypeComponent.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterTypeComponent.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterTypeComponent.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterTypeComponent.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(parameterTypeComponent.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterTypeComponent.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(parameterTypeComponent.Scale.HasValue) - { - writer.WriteStringValue(parameterTypeComponent.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterTypeComponent.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterTypeComponent.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs index 6ffcd74d7..56326cec5 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterValueSetSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,382 +50,6 @@ namespace CDP4JsonSerializer /// public class ParameterValueSetSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "actualoption": - var allowedVersionsForActualOption = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForActualOption.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actualOption"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "actualstate": - var allowedVersionsForActualState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForActualState.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actualState"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "computed": - var allowedVersionsForComputed = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForComputed.Contains(requestedVersion)) - { - return; - } - - writer.WriteString("computed"u8, ((ValueArray)value).ToJsonString()); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "formula": - var allowedVersionsForFormula = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFormula.Contains(requestedVersion)) - { - return; - } - - writer.WriteString("formula"u8, ((ValueArray)value).ToJsonString()); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "manual": - var allowedVersionsForManual = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForManual.Contains(requestedVersion)) - { - return; - } - - writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "published": - var allowedVersionsForPublished = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPublished.Contains(requestedVersion)) - { - return; - } - - writer.WriteString("published"u8, ((ValueArray)value).ToJsonString()); - break; - case "reference": - var allowedVersionsForReference = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReference.Contains(requestedVersion)) - { - return; - } - - writer.WriteString("reference"u8, ((ValueArray)value).ToJsonString()); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "valueswitch": - var allowedVersionsForValueSwitch = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueSwitch.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("valueSwitch"u8); - - if(value != null) - { - writer.WriteStringValue(((ParameterSwitchKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterValueSet"); - } - } - /// /// Serializes a into an /// @@ -451,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing ParameterValueSet for Version 1.0.0"); writer.WritePropertyName("actualOption"u8); if(parameterValueSet.ActualOption.HasValue) @@ -489,7 +114,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing ParameterValueSet for Version 1.1.0"); writer.WritePropertyName("actualOption"u8); if(parameterValueSet.ActualOption.HasValue) @@ -523,6 +148,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -531,6 +157,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); writer.WritePropertyName("iid"u8); writer.WriteStringValue(parameterValueSet.Iid); @@ -545,7 +172,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing ParameterValueSet for Version 1.2.0"); writer.WritePropertyName("actualOption"u8); if(parameterValueSet.ActualOption.HasValue) @@ -579,6 +206,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -587,6 +215,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); writer.WritePropertyName("iid"u8); writer.WriteStringValue(parameterValueSet.Iid); @@ -603,7 +232,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(parameterValueSet.ValueSwitch.ToString()); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterValueSet for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing ParameterValueSet for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(parameterValueSet.Actor.HasValue) @@ -648,6 +277,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parameterValueSet.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -656,6 +286,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteString("formula"u8, parameterValueSet.Formula.ToJsonString()); writer.WritePropertyName("iid"u8); writer.WriteStringValue(parameterValueSet.Iid); @@ -677,6 +308,286 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualoption": + if(!AllowedVersionsPerProperty["actualOption"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualOption"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "actualstate": + if(!AllowedVersionsPerProperty["actualState"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actualState"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "computed": + if(!AllowedVersionsPerProperty["computed"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("computed"u8, ((ValueArray)value).ToJsonString()); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "formula": + if(!AllowedVersionsPerProperty["formula"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("formula"u8, ((ValueArray)value).ToJsonString()); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "manual": + if(!AllowedVersionsPerProperty["manual"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("manual"u8, ((ValueArray)value).ToJsonString()); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "published": + if(!AllowedVersionsPerProperty["published"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("published"u8, ((ValueArray)value).ToJsonString()); + break; + case "reference": + if(!AllowedVersionsPerProperty["reference"].Contains(requestedVersion)) + { + return; + } + + writer.WriteString("reference"u8, ((ValueArray)value).ToJsonString()); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valueswitch": + if(!AllowedVersionsPerProperty["valueSwitch"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueSwitch"u8); + + if(value != null) + { + writer.WriteStringValue(((ParameterSwitchKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterValueSet"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "actualOption", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "actualState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "computed", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "formula", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "manual", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "published", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "reference", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueSwitch", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs index b300a61d0..a55f0d555 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParameterizedCategoryRuleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,317 +51,349 @@ namespace CDP4JsonSerializer public class ParameterizedCategoryRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ParameterizedCategoryRule parameterizedCategoryRule) + { + throw new ArgumentException("The thing shall be a ParameterizedCategoryRule", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ParameterizedCategoryRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterizedCategoryRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); - if(value is IEnumerable objectListAlias) + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(parameterTypeItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterizedCategoryRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("category"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); - if(value is IEnumerable objectListDefinition) + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(parameterTypeItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterizedCategoryRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterTypeItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParameterizedCategoryRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(parameterizedCategoryRule.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(parameterizedCategoryRule.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("category"u8); + writer.WriteStringValue(parameterizedCategoryRule.Category); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(parameterizedCategoryRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(parameterizedCategoryRule.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(parameterTypeItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(parameterizedCategoryRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForName.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -368,51 +401,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("parameterType"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListParameterType) + if(value is IEnumerable objectListAlias) { - foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterTypeItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("category"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -420,25 +437,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterizedCategoryRule"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ParameterizedCategoryRule parameterizedCategoryRule) - { - throw new ArgumentException("The thing shall be a ParameterizedCategoryRule", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParameterizedCategoryRule since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("category"u8); - writer.WriteStringValue(parameterizedCategoryRule.Category); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(definitionItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterizedCategoryRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterizedCategoryRule.Name); - writer.WriteStartArray("parameterType"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(parameterTypeItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterizedCategoryRule.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("category"u8); - writer.WriteStringValue(parameterizedCategoryRule.Category); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterizedCategoryRule.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterizedCategoryRule.Name); - writer.WriteStartArray("parameterType"u8); - - foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(parameterTypeItem); + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterizedCategoryRule.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("category"u8); - writer.WriteStringValue(parameterizedCategoryRule.Category); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "parametertype": + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterizedCategoryRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterizedCategoryRule.Name); writer.WriteStartArray("parameterType"u8); - foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterType) { - writer.WriteStringValue(parameterTypeItem); + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterizedCategoryRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParameterizedCategoryRule for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(parameterizedCategoryRule.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(parameterizedCategoryRule.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in parameterizedCategoryRule.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("category"u8); - writer.WriteStringValue(parameterizedCategoryRule.Category); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(parameterizedCategoryRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in parameterizedCategoryRule.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in parameterizedCategoryRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in parameterizedCategoryRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in parameterizedCategoryRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(parameterizedCategoryRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(parameterizedCategoryRule.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(parameterizedCategoryRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(parameterizedCategoryRule.Name); - writer.WriteStartArray("parameterType"u8); - - foreach(var parameterTypeItem in parameterizedCategoryRule.ParameterType.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(parameterTypeItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(parameterizedCategoryRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(parameterizedCategoryRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(parameterizedCategoryRule.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParameterizedCategoryRule"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs index 767379e48..225ac2c7e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParametricConstraintSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,276 +50,6 @@ namespace CDP4JsonSerializer /// public class ParametricConstraintSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "expression": - var allowedVersionsForExpression = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExpression.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("expression"u8); - - if(value is IEnumerable objectListExpression) - { - foreach(var expressionItem in objectListExpression.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(expressionItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "topexpression": - var allowedVersionsForTopExpression = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTopExpression.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("topExpression"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ParametricConstraint"); - } - } - /// /// Serializes a into an /// @@ -345,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing ParametricConstraint for Version 1.0.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); writer.WriteStartArray("expression"u8); @@ -356,6 +87,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(parametricConstraint.Iid); writer.WritePropertyName("revisionNumber"u8); @@ -373,7 +105,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing ParametricConstraint for Version 1.1.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -384,6 +116,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -392,6 +125,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) @@ -400,6 +134,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(parametricConstraint.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -419,7 +154,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing ParametricConstraint for Version 1.2.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(parametricConstraint.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -430,6 +165,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -438,6 +174,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) @@ -446,6 +183,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(parametricConstraint.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -467,7 +205,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParametricConstraint for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing ParametricConstraint for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(parametricConstraint.Actor.HasValue) @@ -489,6 +227,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in parametricConstraint.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +236,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("expression"u8); foreach(var expressionItem in parametricConstraint.Expression.OrderBy(x => x, this.GuidComparer)) @@ -505,6 +245,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(parametricConstraint.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -531,6 +272,222 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "expression": + if(!AllowedVersionsPerProperty["expression"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("expression"u8); + + if(value is IEnumerable objectListExpression) + { + foreach(var expressionItem in objectListExpression.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(expressionItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "topexpression": + if(!AllowedVersionsPerProperty["topExpression"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("topExpression"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParametricConstraint"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "expression", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "topExpression", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs index d3241fb99..1f5e997d1 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantPermissionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class ParticipantPermissionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ParticipantPermission participantPermission) + { + throw new ArgumentException("The thing shall be a ParticipantPermission", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantPermission since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantPermission for Version 1.0.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantPermission for Version 1.1.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantPermission for Version 1.2.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantPermission.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantPermission for Version 1.3.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(participantPermission.AccessRight.ToString()); + writer.WritePropertyName("actor"u8); + + if(participantPermission.Actor.HasValue) + { + writer.WriteStringValue(participantPermission.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(participantPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantPermission.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class ParticipantPermissionSerializer : BaseThingSerializer, IThingSerial /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,15 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "accessright": - var allowedVersionsForAccessRight = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAccessRight.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["accessRight"].Contains(requestedVersion)) { return; } @@ -89,12 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -112,15 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -138,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -240,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "objectclass": - var allowedVersionsForObjectClass = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForObjectClass.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["objectClass"].Contains(requestedVersion)) { return; } @@ -291,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ParticipantPermission participantPermission) - { - throw new ArgumentException("The thing shall be a ParticipantPermission", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantPermission since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.0.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(participantPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantPermission.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantPermission.IsDeprecated); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(participantPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantPermission.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.1.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(participantPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(participantPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantPermission.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.2.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(participantPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(participantPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantPermission.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participantPermission.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantPermission for Version 1.3.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(participantPermission.AccessRight.ToString()); - writer.WritePropertyName("actor"u8); - - if(participantPermission.Actor.HasValue) - { - writer.WriteStringValue(participantPermission.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(participantPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantPermission.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participantPermission.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "accessRight", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "objectClass", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs index 8d97e9a73..6e9fdced3 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantRoleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,291 +51,341 @@ namespace CDP4JsonSerializer public class ParticipantRoleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ParticipantRole participantRole) + { + throw new ArgumentException("The thing shall be a ParticipantRole", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantRole since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantRole for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); - if(value is IEnumerable objectListAlias) + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(participantPermissionItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantRole for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(participantPermissionItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantRole for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(participantPermissionItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantRole.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ParticipantRole for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(participantRole.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(participantRole.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participantRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participantRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(participantRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(participantRole.Name); + writer.WriteStartArray("participantPermission"u8); + + foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(participantPermissionItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participantRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(participantRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participantRole.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForName.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -342,51 +393,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "participantpermission": - var allowedVersionsForParticipantPermission = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParticipantPermission.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("participantPermission"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListParticipantPermission) + if(value is IEnumerable objectListAlias) { - foreach(var participantPermissionItem in objectListParticipantPermission.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(participantPermissionItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -394,349 +429,248 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue((string)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ParticipantRole"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ParticipantRole participantRole) - { - throw new ArgumentException("The thing shall be a ParticipantRole", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ParticipantRole since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(aliasItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantRole.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(participantRole.Name); - writer.WriteStartArray("participantPermission"u8); - - foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(participantPermissionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(participantRole.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantRole.IsDeprecated); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(participantRole.Name); - writer.WriteStartArray("participantPermission"u8); - - foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(participantPermissionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(participantRole.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "participantpermission": + if(!AllowedVersionsPerProperty["participantPermission"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantRole.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(participantRole.Name); writer.WriteStartArray("participantPermission"u8); - foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParticipantPermission) { - writer.WriteStringValue(participantPermissionItem); + foreach(var participantPermissionItem in objectListParticipantPermission.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantPermissionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(participantRole.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participantRole.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ParticipantRole for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(participantRole.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(participantRole.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in participantRole.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participantRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in participantRole.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participantRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participantRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in participantRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participantRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(participantRole.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participantRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(participantRole.Name); - writer.WriteStartArray("participantPermission"u8); - - foreach(var participantPermissionItem in participantRole.ParticipantPermission.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(participantPermissionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participantRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(participantRole.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participantRole.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ParticipantRole"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "participantPermission", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs index e178a731d..1f162cfc0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ParticipantSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,217 @@ namespace CDP4JsonSerializer /// public class ParticipantSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Participant participant) + { + throw new ArgumentException("The thing shall be a Participant", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Participant since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Participant for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Participant for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Participant for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participant.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Participant for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(participant.Actor.HasValue) + { + writer.WriteStringValue(participant.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(participant.ClassKind.ToString()); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(participant.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(participant.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("person"u8); + writer.WriteStringValue(participant.Person); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(participant.RevisionNumber); + writer.WritePropertyName("role"u8); + writer.WriteStringValue(participant.Role); + writer.WritePropertyName("selectedDomain"u8); + writer.WriteStringValue(participant.SelectedDomain); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(participant.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +268,7 @@ public class ParticipantSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +276,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +294,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +312,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "domain": - var allowedVersionsForDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["domain"].Contains(requestedVersion)) { return; } @@ -138,14 +330,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +348,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +366,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +384,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isactive": - var allowedVersionsForIsActive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsActive.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isActive"].Contains(requestedVersion)) { return; } @@ -240,14 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +420,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "person": - var allowedVersionsForPerson = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["person"].Contains(requestedVersion)) { return; } @@ -291,15 +438,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,15 +456,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "role": - var allowedVersionsForRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRole.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["role"].Contains(requestedVersion)) { return; } @@ -343,15 +474,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "selecteddomain": - var allowedVersionsForSelectedDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSelectedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["selectedDomain"].Contains(requestedVersion)) { return; } @@ -369,13 +492,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -398,205 +515,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Participant participant) - { - throw new ArgumentException("The thing shall be a Participant", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Participant since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participant.ClassKind.ToString()); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participant.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(participant.IsActive); - writer.WritePropertyName("person"u8); - writer.WriteStringValue(participant.Person); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participant.RevisionNumber); - writer.WritePropertyName("role"u8); - writer.WriteStringValue(participant.Role); - writer.WritePropertyName("selectedDomain"u8); - writer.WriteStringValue(participant.SelectedDomain); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participant.ClassKind.ToString()); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participant.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(participant.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("person"u8); - writer.WriteStringValue(participant.Person); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participant.RevisionNumber); - writer.WritePropertyName("role"u8); - writer.WriteStringValue(participant.Role); - writer.WritePropertyName("selectedDomain"u8); - writer.WriteStringValue(participant.SelectedDomain); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participant.ClassKind.ToString()); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participant.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(participant.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("person"u8); - writer.WriteStringValue(participant.Person); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participant.RevisionNumber); - writer.WritePropertyName("role"u8); - writer.WriteStringValue(participant.Role); - writer.WritePropertyName("selectedDomain"u8); - writer.WriteStringValue(participant.SelectedDomain); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participant.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Participant for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(participant.Actor.HasValue) - { - writer.WriteStringValue(participant.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(participant.ClassKind.ToString()); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in participant.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in participant.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in participant.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(participant.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(participant.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(participant.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("person"u8); - writer.WriteStringValue(participant.Person); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(participant.RevisionNumber); - writer.WritePropertyName("role"u8); - writer.WriteStringValue(participant.Role); - writer.WritePropertyName("selectedDomain"u8); - writer.WriteStringValue(participant.SelectedDomain); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(participant.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "domain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isActive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "person", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "role", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "selectedDomain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs index d253e3ace..a9ffb3fa6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonPermissionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,173 @@ namespace CDP4JsonSerializer /// public class PersonPermissionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not PersonPermission personPermission) + { + throw new ArgumentException("The thing shall be a PersonPermission", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of PersonPermission since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing PersonPermission for Version 1.0.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing PersonPermission for Version 1.1.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing PersonPermission for Version 1.2.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personPermission.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing PersonPermission for Version 1.3.0"); + writer.WritePropertyName("accessRight"u8); + writer.WriteStringValue(personPermission.AccessRight.ToString()); + writer.WritePropertyName("actor"u8); + + if(personPermission.Actor.HasValue) + { + writer.WriteStringValue(personPermission.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personPermission.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personPermission.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personPermission.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("objectClass"u8); + writer.WriteStringValue(personPermission.ObjectClass.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personPermission.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personPermission.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +224,7 @@ public class PersonPermissionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,15 +232,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "accessright": - var allowedVersionsForAccessRight = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAccessRight.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["accessRight"].Contains(requestedVersion)) { return; } @@ -89,12 +250,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -112,15 +268,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -138,14 +286,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +304,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +322,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +340,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -240,14 +358,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +376,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "objectclass": - var allowedVersionsForObjectClass = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForObjectClass.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["objectClass"].Contains(requestedVersion)) { return; } @@ -291,15 +394,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +412,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,165 +435,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not PersonPermission personPermission) - { - throw new ArgumentException("The thing shall be a PersonPermission", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of PersonPermission since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.0.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(personPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personPermission.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personPermission.IsDeprecated); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(personPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personPermission.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.1.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(personPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(personPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personPermission.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.2.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(personPermission.AccessRight.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(personPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personPermission.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(personPermission.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing PersonPermission for Version 1.3.0"); - writer.WritePropertyName("accessRight"u8); - writer.WriteStringValue(personPermission.AccessRight.ToString()); - writer.WritePropertyName("actor"u8); - - if(personPermission.Actor.HasValue) - { - writer.WriteStringValue(personPermission.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personPermission.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personPermission.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personPermission.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personPermission.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personPermission.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personPermission.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("objectClass"u8); - writer.WriteStringValue(personPermission.ObjectClass.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personPermission.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(personPermission.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "accessRight", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "objectClass", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs index 6fecd76eb..780e0d508 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonRoleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,291 +51,341 @@ namespace CDP4JsonSerializer public class PersonRoleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not PersonRole personRole) + { + throw new ArgumentException("The thing shall be a PersonRole", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of PersonRole since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing PersonRole for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); - if(value is IEnumerable objectListAlias) + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(personPermissionItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing PersonRole for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(personPermissionItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing PersonRole for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(personPermissionItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personRole.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing PersonRole for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(personRole.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(personRole.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(personRole.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(personRole.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(personRole.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(personRole.Name); + writer.WriteStartArray("personPermission"u8); + + foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(personPermissionItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(personRole.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(personRole.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(personRole.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForName.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -342,51 +393,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "personpermission": - var allowedVersionsForPersonPermission = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPersonPermission.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("personPermission"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListPersonPermission) + if(value is IEnumerable objectListAlias) { - foreach(var personPermissionItem in objectListPersonPermission.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(personPermissionItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -394,349 +429,248 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue((string)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the PersonRole"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not PersonRole personRole) - { - throw new ArgumentException("The thing shall be a PersonRole", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of PersonRole since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(aliasItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personRole.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(personRole.Name); - writer.WriteStartArray("personPermission"u8); - - foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(personPermissionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(personRole.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personRole.IsDeprecated); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(personRole.Name); - writer.WriteStartArray("personPermission"u8); - - foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(personPermissionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(personRole.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "personpermission": + if(!AllowedVersionsPerProperty["personPermission"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personRole.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(personRole.Name); writer.WriteStartArray("personPermission"u8); - foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPersonPermission) { - writer.WriteStringValue(personPermissionItem); + foreach(var personPermissionItem in objectListPersonPermission.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personPermissionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(personRole.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(personRole.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing PersonRole for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(personRole.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(personRole.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in personRole.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(personRole.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in personRole.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in personRole.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in personRole.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in personRole.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(personRole.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(personRole.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(personRole.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(personRole.Name); - writer.WriteStartArray("personPermission"u8); - - foreach(var personPermissionItem in personRole.PersonPermission.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(personPermissionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(personRole.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(personRole.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(personRole.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the PersonRole"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "personPermission", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs index 632571c77..5c6802131 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PersonSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,640 +51,262 @@ namespace CDP4JsonSerializer public class PersonSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not Person person) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a Person", nameof(thing)); + } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Person since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Person for Version 1.0.0"); writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "defaultdomain": - var allowedVersionsForDefaultDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefaultDomain.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(person.ClassKind.ToString()); writer.WritePropertyName("defaultDomain"u8); - - if(value != null) + + if(person.DefaultDomain.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(person.DefaultDomain.Value); } else { writer.WriteNullValue(); } - break; - case "defaultemailaddress": - var allowedVersionsForDefaultEmailAddress = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefaultEmailAddress.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("defaultEmailAddress"u8); - - if(value != null) + + if(person.DefaultEmailAddress.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(person.DefaultEmailAddress.Value); } else { writer.WriteNullValue(); } - break; - case "defaulttelephonenumber": - var allowedVersionsForDefaultTelephoneNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefaultTelephoneNumber.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("defaultTelephoneNumber"u8); - - if(value != null) + + if(person.DefaultTelephoneNumber.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); } else { writer.WriteNullValue(); } - break; - case "emailaddress": - var allowedVersionsForEmailAddress = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForEmailAddress.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("emailAddress"u8); - if(value is IEnumerable objectListEmailAddress) - { - foreach(var emailAddressItem in objectListEmailAddress.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(emailAddressItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(emailAddressItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "givenname": - var allowedVersionsForGivenName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForGivenName.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("givenName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(person.GivenName); writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isactive": - var allowedVersionsForIsActive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsActive.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(person.Iid); writer.WritePropertyName("isActive"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) - { - return; - } - + writer.WriteBooleanValue(person.IsActive); writer.WritePropertyName("isDeprecated"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("organization"u8); - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) + if(person.Organization.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(person.Organization.Value); } else { writer.WriteNullValue(); } - break; - case "organization": - var allowedVersionsForOrganization = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOrganization.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); - writer.WritePropertyName("organization"u8); - - if(value != null) + if(person.Role.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(person.Role.Value); } else { writer.WriteNullValue(); } - break; - case "organizationalunit": - var allowedVersionsForOrganizationalUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); - if(!allowedVersionsForOrganizationalUnit.Contains(requestedVersion)) + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(telephoneNumberItem); } - writer.WritePropertyName("organizationalUnit"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "password": - var allowedVersionsForPassword = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("userPreference"u8); - if(!allowedVersionsForPassword.Contains(requestedVersion)) + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(userPreferenceItem); } - writer.WritePropertyName("password"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Person for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(person.ClassKind.ToString()); + writer.WritePropertyName("defaultDomain"u8); - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) + if(person.DefaultDomain.HasValue) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(person.DefaultDomain.Value); } else { writer.WriteNullValue(); } - break; - case "role": - var allowedVersionsForRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRole.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("defaultEmailAddress"u8); - writer.WritePropertyName("role"u8); - - if(value != null) + if(person.DefaultEmailAddress.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(person.DefaultEmailAddress.Value); } else { writer.WriteNullValue(); } - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("defaultTelephoneNumber"u8); - writer.WritePropertyName("shortName"u8); - - if(value != null) + if(person.DefaultTelephoneNumber.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(person.DefaultTelephoneNumber.Value); } else { writer.WriteNullValue(); } - break; - case "surname": - var allowedVersionsForSurname = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("emailAddress"u8); - if(!allowedVersionsForSurname.Contains(requestedVersion)) + foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(emailAddressItem); } - writer.WritePropertyName("surname"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "telephonenumber": - var allowedVersionsForTelephoneNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForTelephoneNumber.Contains(requestedVersion)) + foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("telephoneNumber"u8); - - if(value is IEnumerable objectListTelephoneNumber) - { - foreach(var telephoneNumberItem in objectListTelephoneNumber.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(telephoneNumberItem); - } - } - writer.WriteEndArray(); - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("givenName"u8); + writer.WriteStringValue(person.GivenName); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(person.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(person.IsActive); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("organization"u8); + + if(person.Organization.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(person.Organization.Value); } else { writer.WriteNullValue(); } - break; - case "userpreference": - var allowedVersionsForUserPreference = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUserPreference.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("userPreference"u8); + writer.WritePropertyName("organizationalUnit"u8); + writer.WriteStringValue(person.OrganizationalUnit); + writer.WritePropertyName("password"u8); + writer.WriteStringValue(person.Password); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(person.RevisionNumber); + writer.WritePropertyName("role"u8); - if(value is IEnumerable objectListUserPreference) + if(person.Role.HasValue) { - foreach(var userPreferenceItem in objectListUserPreference.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(userPreferenceItem); - } - } - - writer.WriteEndArray(); - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Person"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Person person) - { - throw new ArgumentException("The thing shall be a Person", nameof(thing)); - } + writer.WriteStringValue(person.Role.Value); + } + else + { + writer.WriteNullValue(); + } - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Person since Version is below 1.0.0"); - return; - } + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(person.ShortName); + writer.WritePropertyName("surname"u8); + writer.WriteStringValue(person.Surname); + writer.WriteStartArray("telephoneNumber"u8); - writer.WriteStartObject(); + foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.0.0"); + writer.WriteEndArray(); + + writer.WriteStartArray("userPreference"u8); + + foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Person for Version 1.2.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(person.ClassKind.ToString()); writer.WritePropertyName("defaultDomain"u8); @@ -727,6 +350,25 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); writer.WriteStringValue(person.GivenName); writer.WritePropertyName("iid"u8); @@ -735,6 +377,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteBooleanValue(person.IsActive); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(person.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("organization"u8); if(person.Organization.HasValue) @@ -775,6 +419,9 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(person.ThingPreference); writer.WriteStartArray("userPreference"u8); foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) @@ -783,9 +430,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Person for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(person.Actor.HasValue) + { + writer.WriteStringValue(person.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(person.ClassKind.ToString()); writer.WritePropertyName("defaultDomain"u8); @@ -829,6 +488,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -837,6 +497,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -845,6 +506,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("givenName"u8); writer.WriteStringValue(person.GivenName); writer.WritePropertyName("iid"u8); @@ -895,6 +557,9 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(person.ThingPreference); writer.WriteStartArray("userPreference"u8); foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) @@ -903,268 +568,477 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.2.0"); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(person.ClassKind.ToString()); - writer.WritePropertyName("defaultDomain"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - if(person.DefaultDomain.HasValue) + break; + case "defaultdomain": + if(!AllowedVersionsPerProperty["defaultDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(person.DefaultDomain.Value); + return; + } + + writer.WritePropertyName("defaultDomain"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "defaultemailaddress": + if(!AllowedVersionsPerProperty["defaultEmailAddress"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("defaultEmailAddress"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - if(person.DefaultEmailAddress.HasValue) + break; + case "defaulttelephonenumber": + if(!AllowedVersionsPerProperty["defaultTelephoneNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("defaultTelephoneNumber"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "emailaddress": + if(!AllowedVersionsPerProperty["emailAddress"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("emailAddress"u8); + + if(value is IEnumerable objectListEmailAddress) + { + foreach(var emailAddressItem in objectListEmailAddress.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(emailAddressItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "givenname": + if(!AllowedVersionsPerProperty["givenName"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("givenName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(person.DefaultEmailAddress.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("defaultTelephoneNumber"u8); + break; + case "isactive": + if(!AllowedVersionsPerProperty["isActive"].Contains(requestedVersion)) + { + return; + } - if(person.DefaultTelephoneNumber.HasValue) + writer.WritePropertyName("isActive"u8); + + if(value != null) { - writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("emailAddress"u8); - - foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(emailAddressItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("givenName"u8); - writer.WriteStringValue(person.GivenName); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(person.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(person.IsActive); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(person.IsDeprecated); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("organization"u8); - - if(person.Organization.HasValue) + + if(value != null) { - writer.WriteStringValue(person.Organization.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("organizationalUnit"u8); - writer.WriteStringValue(person.OrganizationalUnit); - writer.WritePropertyName("password"u8); - writer.WriteStringValue(person.Password); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(person.RevisionNumber); - writer.WritePropertyName("role"u8); + break; + case "organization": + if(!AllowedVersionsPerProperty["organization"].Contains(requestedVersion)) + { + return; + } - if(person.Role.HasValue) + writer.WritePropertyName("organization"u8); + + if(value != null) { - writer.WriteStringValue(person.Role.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(person.ShortName); - writer.WritePropertyName("surname"u8); - writer.WriteStringValue(person.Surname); - writer.WriteStartArray("telephoneNumber"u8); - - foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + break; + case "organizationalunit": + if(!AllowedVersionsPerProperty["organizationalUnit"].Contains(requestedVersion)) { - writer.WriteStringValue(telephoneNumberItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(person.ThingPreference); - writer.WriteStartArray("userPreference"u8); - - foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("organizationalUnit"u8); + + if(value != null) { - writer.WriteStringValue(userPreferenceItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Person for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "password": + if(!AllowedVersionsPerProperty["password"].Contains(requestedVersion)) + { + return; + } - if(person.Actor.HasValue) + writer.WritePropertyName("password"u8); + + if(value != null) { - writer.WriteStringValue(person.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(person.ClassKind.ToString()); - writer.WritePropertyName("defaultDomain"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(person.DefaultDomain.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(person.DefaultDomain.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("defaultEmailAddress"u8); + break; + case "role": + if(!AllowedVersionsPerProperty["role"].Contains(requestedVersion)) + { + return; + } - if(person.DefaultEmailAddress.HasValue) + writer.WritePropertyName("role"u8); + + if(value != null) { - writer.WriteStringValue(person.DefaultEmailAddress.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("defaultTelephoneNumber"u8); + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(person.DefaultTelephoneNumber.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(person.DefaultTelephoneNumber.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("emailAddress"u8); - - foreach(var emailAddressItem in person.EmailAddress.OrderBy(x => x, this.GuidComparer)) + break; + case "surname": + if(!AllowedVersionsPerProperty["surname"].Contains(requestedVersion)) { - writer.WriteStringValue(emailAddressItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in person.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("surname"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in person.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "telephonenumber": + if(!AllowedVersionsPerProperty["telephoneNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("givenName"u8); - writer.WriteStringValue(person.GivenName); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(person.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(person.IsActive); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(person.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(person.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("organization"u8); + writer.WriteStartArray("telephoneNumber"u8); - if(person.Organization.HasValue) + if(value is IEnumerable objectListTelephoneNumber) { - writer.WriteStringValue(person.Organization.Value); + foreach(var telephoneNumberItem in objectListTelephoneNumber.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(telephoneNumberItem); + } } - else + + writer.WriteEndArray(); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WritePropertyName("organizationalUnit"u8); - writer.WriteStringValue(person.OrganizationalUnit); - writer.WritePropertyName("password"u8); - writer.WriteStringValue(person.Password); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(person.RevisionNumber); - writer.WritePropertyName("role"u8); - - if(person.Role.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(person.Role.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(person.ShortName); - writer.WritePropertyName("surname"u8); - writer.WriteStringValue(person.Surname); - writer.WriteStartArray("telephoneNumber"u8); - - foreach(var telephoneNumberItem in person.TelephoneNumber.OrderBy(x => x, this.GuidComparer)) + break; + case "userpreference": + if(!AllowedVersionsPerProperty["userPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(telephoneNumberItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(person.ThingPreference); writer.WriteStartArray("userPreference"u8); - foreach(var userPreferenceItem in person.UserPreference.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUserPreference) { - writer.WriteStringValue(userPreferenceItem); + foreach(var userPreferenceItem in objectListUserPreference.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(userPreferenceItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Person"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultDomain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultEmailAddress", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultTelephoneNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "emailAddress", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "givenName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isActive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "organization", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "organizationalUnit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "password", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "role", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "surname", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "telephoneNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "userPreference", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs index 971c3903f..4140edf0e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PointSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,158 @@ namespace CDP4JsonSerializer /// public class PointSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Point point) + { + throw new ArgumentException("The thing shall be a Point", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Point since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Point for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Point for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(point.ThingPreference); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Point for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(point.Actor.HasValue) + { + writer.WriteStringValue(point.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(point.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(point.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(point.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(point.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(point.ThingPreference); + writer.WritePropertyName("x"u8); + writer.WriteNumberValue(point.X); + writer.WritePropertyName("y"u8); + writer.WriteNumberValue(point.Y); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +209,7 @@ public class PointSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +217,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +235,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +253,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +271,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +289,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -186,14 +307,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -211,14 +325,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -236,14 +343,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -261,13 +361,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -285,14 +379,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "x": - var allowedVersionsForX = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForX.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["x"].Contains(requestedVersion)) { return; } @@ -310,14 +397,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "y": - var allowedVersionsForY = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForY.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["y"].Contains(requestedVersion)) { return; } @@ -340,150 +420,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Point point) - { - throw new ArgumentException("The thing shall be a Point", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Point since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(point.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(point.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(point.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(point.RevisionNumber); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(point.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(point.Y); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(point.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(point.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(point.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(point.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(point.ThingPreference); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(point.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(point.Y); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Point for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(point.Actor.HasValue) - { - writer.WriteStringValue(point.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(point.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in point.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in point.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(point.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(point.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(point.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(point.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(point.ThingPreference); - writer.WritePropertyName("x"u8); - writer.WriteNumberValue(point.X); - writer.WritePropertyName("y"u8); - writer.WriteNumberValue(point.Y); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "x", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "y", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs index 0d1cd3b88..4c5bea084 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateListSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,521 +51,252 @@ namespace CDP4JsonSerializer public class PossibleFiniteStateListSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not PossibleFiniteStateList possibleFiniteStateList) + { + throw new ArgumentException("The thing shall be a PossibleFiniteStateList", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List + Logger.Log(LogLevel.Info, "Skipping serialization of PossibleFiniteStateList since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteStateList for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) { - "1.3.0", - }; + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); } else { writer.WriteNullValue(); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); - - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); - if(value is IEnumerable objectListCategory) + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteOrderedItem(possibleStateItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteStateList for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "defaultstate": - var allowedVersionsForDefaultState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForDefaultState.Contains(requestedVersion)) + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("defaultState"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); } else { writer.WriteNullValue(); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(possibleFiniteStateList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(possibleFiniteStateList.Owner); + writer.WriteStartArray("possibleState"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteOrderedItem(possibleStateItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(possibleFiniteStateList.ShortName); break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteStateList for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); + writer.WritePropertyName("defaultState"u8); + + if(possibleFiniteStateList.DefaultState.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("owner"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "possiblestate": - var allowedVersionsForPossibleState = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPossibleState.Contains(requestedVersion)) - { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("possibleState"u8); - - if(value is IEnumerable objectListPossibleState) - { - foreach(var possibleStateItem in objectListPossibleState.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(possibleStateItem); - } - } - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteStateList"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not PossibleFiniteStateList possibleFiniteStateList) - { - throw new ArgumentException("The thing shall be a PossibleFiniteStateList", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of PossibleFiniteStateList since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); - writer.WritePropertyName("defaultState"u8); - - if(possibleFiniteStateList.DefaultState.HasValue) - { - writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -573,8 +305,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteStateList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(possibleFiniteStateList.Name); writer.WritePropertyName("owner"u8); @@ -587,13 +322,27 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(possibleFiniteStateList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteStateList.ThingPreference); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteStateList for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(possibleFiniteStateList.Actor.HasValue) + { + writer.WriteStringValue(possibleFiniteStateList.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) @@ -602,6 +351,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("category"u8); foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) @@ -610,6 +360,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); writer.WritePropertyName("defaultState"u8); @@ -631,6 +382,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -639,6 +391,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -647,6 +400,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -655,6 +409,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteStateList.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -671,200 +426,369 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(possibleFiniteStateList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(possibleFiniteStateList.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.2.0"); - writer.WriteStartArray("alias"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); - writer.WritePropertyName("defaultState"u8); - - if(possibleFiniteStateList.DefaultState.HasValue) + writer.WritePropertyName("actor"u8); + + if(value != null) { - writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("alias"u8); - foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(excludedDomainItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("category"u8); - foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListCategory) { - writer.WriteStringValue(hyperLinkItem); + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(possibleFiniteStateList.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(possibleFiniteStateList.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(possibleFiniteStateList.Owner); - writer.WriteStartArray("possibleState"u8); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } - foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + writer.WritePropertyName("classKind"u8); + + if(value != null) { - writer.WriteOrderedItem(possibleStateItem); + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(possibleFiniteStateList.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(possibleFiniteStateList.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteStateList for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "defaultstate": + if(!AllowedVersionsPerProperty["defaultState"].Contains(requestedVersion)) + { + return; + } - if(possibleFiniteStateList.Actor.HasValue) + writer.WritePropertyName("defaultState"u8); + + if(value != null) { - writer.WriteStringValue(possibleFiniteStateList.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } - foreach(var aliasItem in possibleFiniteStateList.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(aliasItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } - foreach(var categoryItem in possibleFiniteStateList.Category.OrderBy(x => x, this.GuidComparer)) + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; } + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(possibleFiniteStateList.ClassKind.ToString()); - writer.WritePropertyName("defaultState"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(possibleFiniteStateList.DefaultState.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(possibleFiniteStateList.DefaultState.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in possibleFiniteStateList.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } - foreach(var excludedDomainItem in possibleFiniteStateList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var excludedPersonItem in possibleFiniteStateList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WritePropertyName("owner"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var hyperLinkItem in possibleFiniteStateList.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "possiblestate": + if(!AllowedVersionsPerProperty["possibleState"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(possibleFiniteStateList.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(possibleFiniteStateList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(possibleFiniteStateList.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(possibleFiniteStateList.Owner); writer.WriteStartArray("possibleState"u8); - foreach(var possibleStateItem in possibleFiniteStateList.PossibleState.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListPossibleState) { - writer.WriteOrderedItem(possibleStateItem); + foreach(var possibleStateItem in objectListPossibleState.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(possibleStateItem); + } } - + writer.WriteEndArray(); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(possibleFiniteStateList.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(possibleFiniteStateList.ShortName); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(possibleFiniteStateList.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteStateList"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleState", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs index 8829ee1bb..0d47f7b5c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PossibleFiniteStateSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,354 +50,6 @@ namespace CDP4JsonSerializer /// public class PossibleFiniteStateSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("alias"u8); - - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteState"); - } - } - /// /// Serializes a into an /// @@ -423,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.0.0"); + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteState for Version 1.0.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) @@ -432,6 +85,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -442,6 +96,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -450,6 +105,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteState.Iid); writer.WritePropertyName("name"u8); @@ -460,7 +116,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(possibleFiniteState.ShortName); break; case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteState for Version 1.1.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) @@ -469,6 +125,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -479,6 +136,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -487,6 +145,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -495,6 +154,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -503,6 +163,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteState.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -515,7 +176,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(possibleFiniteState.ShortName); break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteState for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in possibleFiniteState.Alias.OrderBy(x => x, this.GuidComparer)) @@ -524,6 +185,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -534,6 +196,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -542,6 +205,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -550,6 +214,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -558,6 +223,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteState.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -572,7 +238,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(possibleFiniteState.ThingPreference); break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing PossibleFiniteState for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing PossibleFiniteState for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(possibleFiniteState.Actor.HasValue) @@ -592,6 +258,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(possibleFiniteState.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -602,6 +269,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in possibleFiniteState.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -610,6 +278,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in possibleFiniteState.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -618,6 +287,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in possibleFiniteState.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -626,6 +296,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(possibleFiniteState.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -645,6 +316,279 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("name"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the PossibleFiniteState"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs index f6ed496f1..42104de74 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PrefixedUnitSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,424 +51,112 @@ namespace CDP4JsonSerializer public class PrefixedUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not PrefixedUnit prefixedUnit) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a PrefixedUnit", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of PrefixedUnit since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing PrefixedUnit for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(prefixedUnit.Iid); writer.WritePropertyName("isDeprecated"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "prefix": - var allowedVersionsForPrefix = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrefix.Contains(requestedVersion)) - { - return; - } - + writer.WriteBooleanValue(prefixedUnit.IsDeprecated); writer.WritePropertyName("prefix"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "referenceunit": - var allowedVersionsForReferenceUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferenceUnit.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(prefixedUnit.Prefix); writer.WritePropertyName("referenceUnit"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WriteStringValue(prefixedUnit.ReferenceUnit); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(prefixedUnit.RevisionNumber); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing PrefixedUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the PrefixedUnit"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not PrefixedUnit prefixedUnit) - { - throw new ArgumentException("The thing shall be a PrefixedUnit", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of PrefixedUnit since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(excludedDomainItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -476,10 +165,13 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(prefixedUnit.Iid); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(prefixedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("prefix"u8); writer.WriteStringValue(prefixedUnit.Prefix); writer.WritePropertyName("referenceUnit"u8); @@ -487,8 +179,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(prefixedUnit.RevisionNumber); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing PrefixedUnit for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +189,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -507,6 +200,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -515,6 +209,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -523,6 +218,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -531,6 +227,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(prefixedUnit.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -543,9 +240,22 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteStringValue(prefixedUnit.ReferenceUnit); writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(prefixedUnit.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(prefixedUnit.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing PrefixedUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(prefixedUnit.Actor.HasValue) + { + writer.WriteStringValue(prefixedUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) @@ -554,6 +264,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -564,6 +275,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -572,6 +284,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -580,6 +293,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -588,6 +302,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(prefixedUnit.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -603,82 +318,304 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("thingPreference"u8); writer.WriteStringValue(prefixedUnit.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing PrefixedUnit for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(prefixedUnit.Actor.HasValue) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(prefixedUnit.Actor.Value); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("alias"u8); - foreach(var aliasItem in prefixedUnit.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(aliasItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(prefixedUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var definitionItem in prefixedUnit.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in prefixedUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in prefixedUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in prefixedUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(prefixedUnit.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(prefixedUnit.IsDeprecated); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(prefixedUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "prefix": + if(!AllowedVersionsPerProperty["prefix"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("prefix"u8); - writer.WriteStringValue(prefixedUnit.Prefix); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "referenceunit": + if(!AllowedVersionsPerProperty["referenceUnit"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("referenceUnit"u8); - writer.WriteStringValue(prefixedUnit.ReferenceUnit); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(prefixedUnit.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(prefixedUnit.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the PrefixedUnit"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "prefix", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceUnit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs index 69e006cea..d1beffcf6 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/PublicationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,229 @@ namespace CDP4JsonSerializer /// public class PublicationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Publication publication) + { + throw new ArgumentException("The thing shall be a Publication", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Publication since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Publication for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Publication for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Publication for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(publication.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Publication for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(publication.Actor.HasValue) + { + writer.WriteStringValue(publication.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(publication.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("domain"u8); + + foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(publication.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("publishedParameter"u8); + + foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(publishedParameterItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(publication.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(publication.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +280,7 @@ public class PublicationSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -138,15 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "domain": - var allowedVersionsForDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["domain"].Contains(requestedVersion)) { return; } @@ -164,14 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -189,14 +378,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -214,15 +396,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -240,14 +414,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +432,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "publishedparameter": - var allowedVersionsForPublishedParameter = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPublishedParameter.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["publishedParameter"].Contains(requestedVersion)) { return; } @@ -291,15 +450,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -317,13 +468,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -346,213 +491,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Publication publication) - { - throw new ArgumentException("The thing shall be a Publication", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Publication since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(publication.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(publication.Iid); - writer.WriteStartArray("publishedParameter"u8); - - foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(publishedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(publication.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(publication.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(publication.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("publishedParameter"u8); - - foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(publishedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(publication.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(publication.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(publication.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("publishedParameter"u8); - - foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(publishedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(publication.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(publication.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Publication for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(publication.Actor.HasValue) - { - writer.WriteStringValue(publication.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(publication.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(publication.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in publication.Domain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in publication.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in publication.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(publication.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(publication.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("publishedParameter"u8); - - foreach(var publishedParameterItem in publication.PublishedParameter.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(publishedParameterItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(publication.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(publication.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "domain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "publishedParameter", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs index 0519f1a24..966d9d818 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/QuantityKindFactorSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class QuantityKindFactorSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not QuantityKindFactor quantityKindFactor) + { + throw new ArgumentException("The thing shall be a QuantityKindFactor", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of QuantityKindFactor since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing QuantityKindFactor for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing QuantityKindFactor for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing QuantityKindFactor for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(quantityKindFactor.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing QuantityKindFactor for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(quantityKindFactor.Actor.HasValue) + { + writer.WriteStringValue(quantityKindFactor.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(quantityKindFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(quantityKindFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("quantityKind"u8); + writer.WriteStringValue(quantityKindFactor.QuantityKind); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(quantityKindFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(quantityKindFactor.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class QuantityKindFactorSerializer : BaseThingSerializer, IThingSerialize /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "exponent": - var allowedVersionsForExponent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExponent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["exponent"].Contains(requestedVersion)) { return; } @@ -188,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "quantitykind": - var allowedVersionsForQuantityKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForQuantityKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["quantityKind"].Contains(requestedVersion)) { return; } @@ -265,15 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,13 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not QuantityKindFactor quantityKindFactor) - { - throw new ArgumentException("The thing shall be a QuantityKindFactor", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of QuantityKindFactor since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(quantityKindFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(quantityKindFactor.Iid); - writer.WritePropertyName("quantityKind"u8); - writer.WriteStringValue(quantityKindFactor.QuantityKind); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(quantityKindFactor.RevisionNumber); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(quantityKindFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(quantityKindFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("quantityKind"u8); - writer.WriteStringValue(quantityKindFactor.QuantityKind); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(quantityKindFactor.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(quantityKindFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(quantityKindFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("quantityKind"u8); - writer.WriteStringValue(quantityKindFactor.QuantityKind); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(quantityKindFactor.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(quantityKindFactor.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing QuantityKindFactor for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(quantityKindFactor.Actor.HasValue) - { - writer.WriteStringValue(quantityKindFactor.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(quantityKindFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in quantityKindFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in quantityKindFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(quantityKindFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(quantityKindFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(quantityKindFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("quantityKind"u8); - writer.WriteStringValue(quantityKindFactor.QuantityKind); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(quantityKindFactor.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(quantityKindFactor.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "exponent", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "quantityKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs index 4ad6a83b7..b7edfc24c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RatioScaleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,370 +51,441 @@ namespace CDP4JsonSerializer public class RatioScaleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RatioScale ratioScale) + { + throw new ArgumentException("The thing shall be a RatioScale", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RatioScale since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RatioScale for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(aliasItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RatioScale for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(mappingToReferenceScaleItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(valueDefinitionItem); } - + writer.WriteEndArray(); + break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RatioScale for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(mappingToReferenceScaleItem); } - break; - case "ismaximuminclusive": - var allowedVersionsForIsMaximumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ratioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); - if(!allowedVersionsForIsMaximumInclusive.Contains(requestedVersion)) + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueDefinitionItem); } - writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteEndArray(); - if(value != null) + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RatioScale for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ratioScale.Actor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(ratioScale.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isminimuminclusive": - var allowedVersionsForIsMinimumInclusive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsMinimumInclusive.Contains(requestedVersion)) + foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ratioScale.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "mappingtoreferencescale": - var allowedVersionsForMappingToReferenceScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForMappingToReferenceScale.Contains(requestedVersion)) + foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("mappingToReferenceScale"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListMappingToReferenceScale) + foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(mappingToReferenceScaleItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "maximumpermissiblevalue": - var allowedVersionsForMaximumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForMaximumPermissibleValue.Contains(requestedVersion)) + foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ratioScale.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(ratioScale.IsDeprecated); + writer.WritePropertyName("isMaximumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); + writer.WritePropertyName("isMinimumInclusive"u8); + writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); + writer.WriteStartArray("mappingToReferenceScale"u8); + + foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(mappingToReferenceScaleItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("maximumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MaximumPermissibleValue); + writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WriteStringValue(ratioScale.MinimumPermissibleValue); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ratioScale.Name); + writer.WritePropertyName("negativeValueConnotation"u8); + writer.WriteStringValue(ratioScale.NegativeValueConnotation); + writer.WritePropertyName("numberSet"u8); + writer.WriteStringValue(ratioScale.NumberSet.ToString()); + writer.WritePropertyName("positiveValueConnotation"u8); + writer.WriteStringValue(ratioScale.PositiveValueConnotation); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ratioScale.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ratioScale.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ratioScale.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(ratioScale.Unit); + writer.WriteStartArray("valueDefinition"u8); + + foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(valueDefinitionItem); } + writer.WriteEndArray(); + break; - case "minimumpermissiblevalue": - var allowedVersionsForMinimumPermissibleValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForMinimumPermissibleValue.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("minimumPermissibleValue"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -421,50 +493,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,103 +529,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "negativevalueconnotation": - var allowedVersionsForNegativeValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForNegativeValueConnotation.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("negativeValueConnotation"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "numberset": - var allowedVersionsForNumberSet = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForNumberSet.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) { - return; + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - - writer.WritePropertyName("numberSet"u8); - if(value != null) - { - writer.WriteStringValue(((NumberSetKind)value).ToString()); - } - else + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "positivevalueconnotation": - var allowedVersionsForPositiveValueConnotation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForPositiveValueConnotation.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) { - return; + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - - writer.WritePropertyName("positiveValueConnotation"u8); - if(value != null) + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue((string)value); + return; } - else + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) { - writer.WriteNullValue(); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + + writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -576,25 +619,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -602,23 +637,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "ismaximuminclusive": + if(!AllowedVersionsPerProperty["isMaximumInclusive"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("isMaximumInclusive"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -626,25 +655,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + case "isminimuminclusive": + if(!AllowedVersionsPerProperty["isMinimumInclusive"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("unit"u8); + writer.WritePropertyName("isMinimumInclusive"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteBooleanValue((bool)value); } else { @@ -652,421 +673,275 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "valuedefinition": - var allowedVersionsForValueDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueDefinition.Contains(requestedVersion)) + case "mappingtoreferencescale": + if(!AllowedVersionsPerProperty["mappingToReferenceScale"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("valueDefinition"u8); + writer.WriteStartArray("mappingToReferenceScale"u8); - if(value is IEnumerable objectListValueDefinition) + if(value is IEnumerable objectListMappingToReferenceScale) { - foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var mappingToReferenceScaleItem in objectListMappingToReferenceScale.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue(mappingToReferenceScaleItem); } } writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RatioScale"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RatioScale ratioScale) - { - throw new ArgumentException("The thing shall be a RatioScale", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RatioScale since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "maximumpermissiblevalue": + if(!AllowedVersionsPerProperty["maximumPermissibleValue"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ratioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("maximumPermissibleValue"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ratioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ratioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "minimumpermissiblevalue": + if(!AllowedVersionsPerProperty["minimumPermissibleValue"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MaximumPermissibleValue); writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MinimumPermissibleValue); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ratioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ratioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ratioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ratioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ratioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ratioScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ratioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ratioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ratioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ratioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "negativevalueconnotation": + if(!AllowedVersionsPerProperty["negativeValueConnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ratioScale.Name); writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ratioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ratioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ratioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ratioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ratioScale.ShortName); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ratioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + case "numberset": + if(!AllowedVersionsPerProperty["numberSet"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ratioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("numberSet"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((NumberSetKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "positivevalueconnotation": + if(!AllowedVersionsPerProperty["positiveValueConnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("positiveValueConnotation"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ratioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ratioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ratioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ratioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ratioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ratioScale.PositiveValueConnotation); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ratioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ratioScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ratioScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ratioScale.Unit); - writer.WriteStartArray("valueDefinition"u8); - - foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(valueDefinitionItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RatioScale for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(ratioScale.Actor.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(ratioScale.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ratioScale.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ratioScale.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ratioScale.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ratioScale.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ratioScale.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "unit": + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ratioScale.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("unit"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ratioScale.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(ratioScale.IsDeprecated); - writer.WritePropertyName("isMaximumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMaximumInclusive); - writer.WritePropertyName("isMinimumInclusive"u8); - writer.WriteBooleanValue(ratioScale.IsMinimumInclusive); - writer.WriteStartArray("mappingToReferenceScale"u8); - - foreach(var mappingToReferenceScaleItem in ratioScale.MappingToReferenceScale.OrderBy(x => x, this.GuidComparer)) + break; + case "valuedefinition": + if(!AllowedVersionsPerProperty["valueDefinition"].Contains(requestedVersion)) { - writer.WriteStringValue(mappingToReferenceScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("maximumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MaximumPermissibleValue); - writer.WritePropertyName("minimumPermissibleValue"u8); - writer.WriteStringValue(ratioScale.MinimumPermissibleValue); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ratioScale.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ratioScale.Name); - writer.WritePropertyName("negativeValueConnotation"u8); - writer.WriteStringValue(ratioScale.NegativeValueConnotation); - writer.WritePropertyName("numberSet"u8); - writer.WriteStringValue(ratioScale.NumberSet.ToString()); - writer.WritePropertyName("positiveValueConnotation"u8); - writer.WriteStringValue(ratioScale.PositiveValueConnotation); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ratioScale.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ratioScale.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ratioScale.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(ratioScale.Unit); writer.WriteStartArray("valueDefinition"u8); - foreach(var valueDefinitionItem in ratioScale.ValueDefinition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListValueDefinition) { - writer.WriteStringValue(valueDefinitionItem); + foreach(var valueDefinitionItem in objectListValueDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueDefinitionItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RatioScale"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMaximumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isMinimumInclusive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "mappingToReferenceScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maximumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minimumPermissibleValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "negativeValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "numberSet", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "positiveValueConnotation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "valueDefinition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs index d86691242..c0b47518b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferenceSourceSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,614 +51,254 @@ namespace CDP4JsonSerializer public class ReferenceSourceSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not ReferenceSource referenceSource) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a ReferenceSource", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ReferenceSource since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ReferenceSource for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) - { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); writer.WritePropertyName("isDeprecated"u8); - - if(value != null) + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteNumberValue(referenceSource.PublicationYear.Value); } else { writer.WriteNullValue(); } - break; - case "language": - var allowedVersionsForLanguage = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguage.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("publishedIn"u8); - writer.WritePropertyName("language"u8); - - if(value != null) + if(referenceSource.PublishedIn.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(referenceSource.PublishedIn.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("publisher"u8); - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) + if(referenceSource.Publisher.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(referenceSource.Publisher.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("versionDate"u8); - writer.WritePropertyName("name"u8); - - if(value != null) + if(referenceSource.VersionDate.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); break; - case "publicationyear": - var allowedVersionsForPublicationYear = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ReferenceSource for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForPublicationYear.Contains(requestedVersion)) + foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("publicationYear"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "publishedin": - var allowedVersionsForPublishedIn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("author"u8); + writer.WriteStringValue(referenceSource.Author); + writer.WriteStartArray("category"u8); - if(!allowedVersionsForPublishedIn.Contains(requestedVersion)) + foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("publishedIn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "publisher": - var allowedVersionsForPublisher = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referenceSource.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForPublisher.Contains(requestedVersion)) + foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("publisher"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referenceSource.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referenceSource.IsDeprecated); + writer.WritePropertyName("language"u8); + writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referenceSource.Name); + writer.WritePropertyName("publicationYear"u8); + + if(referenceSource.PublicationYear.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteNumberValue(referenceSource.PublicationYear.Value); } else { writer.WriteNullValue(); } - break; - case "versiondate": - var allowedVersionsForVersionDate = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForVersionDate.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("publishedIn"u8); - writer.WritePropertyName("versionDate"u8); - - if(value != null) + if(referenceSource.PublishedIn.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(referenceSource.PublishedIn.Value); } else { writer.WriteNullValue(); } - break; - case "versionidentifier": - var allowedVersionsForVersionIdentifier = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForVersionIdentifier.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("publisher"u8); - writer.WritePropertyName("versionIdentifier"u8); - - if(value != null) + if(referenceSource.Publisher.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(referenceSource.Publisher.Value); } else { writer.WriteNullValue(); } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ReferenceSource"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ReferenceSource referenceSource) - { - throw new ArgumentException("The thing shall be a ReferenceSource", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ReferenceSource since Version is below 1.0.0"); - return; - } + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referenceSource.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("versionDate"u8); - writer.WriteStartObject(); + if(referenceSource.VersionDate.HasValue) + { + writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.0.0"); + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ReferenceSource for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) @@ -666,6 +307,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("author"u8); writer.WriteStringValue(referenceSource.Author); writer.WriteStartArray("category"u8); @@ -676,6 +318,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(referenceSource.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -686,6 +329,25 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -694,12 +356,15 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(referenceSource.Iid); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(referenceSource.IsDeprecated); writer.WritePropertyName("language"u8); writer.WriteStringValue(referenceSource.Language); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(referenceSource.Name); writer.WritePropertyName("publicationYear"u8); @@ -739,6 +404,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(referenceSource.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referenceSource.ThingPreference); writer.WritePropertyName("versionDate"u8); if(referenceSource.VersionDate.HasValue) @@ -753,8 +420,19 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("versionIdentifier"u8); writer.WriteStringValue(referenceSource.VersionIdentifier); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ReferenceSource for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(referenceSource.Actor.HasValue) + { + writer.WriteStringValue(referenceSource.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) @@ -763,6 +441,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("author"u8); writer.WriteStringValue(referenceSource.Author); writer.WriteStartArray("category"u8); @@ -773,6 +452,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(referenceSource.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -783,6 +463,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -791,6 +472,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -799,6 +481,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -807,6 +490,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(referenceSource.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -854,6 +538,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(referenceSource.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(referenceSource.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referenceSource.ThingPreference); writer.WritePropertyName("versionDate"u8); if(referenceSource.VersionDate.HasValue) @@ -865,260 +551,459 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } - writer.WritePropertyName("versionIdentifier"u8); - writer.WriteStringValue(referenceSource.VersionIdentifier); + writer.WritePropertyName("versionIdentifier"u8); + writer.WriteStringValue(referenceSource.VersionIdentifier); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("author"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(referenceSource.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referenceSource.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "language": + if(!AllowedVersionsPerProperty["language"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referenceSource.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referenceSource.IsDeprecated); writer.WritePropertyName("language"u8); - writer.WriteStringValue(referenceSource.Language); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referenceSource.Name); - writer.WritePropertyName("publicationYear"u8); - - if(referenceSource.PublicationYear.HasValue) + + if(value != null) { - writer.WriteNumberValue(referenceSource.PublicationYear.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("publishedIn"u8); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.PublishedIn.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.PublishedIn.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("publisher"u8); + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.Publisher.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.Publisher.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referenceSource.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referenceSource.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(referenceSource.ThingPreference); - writer.WritePropertyName("versionDate"u8); + break; + case "publicationyear": + if(!AllowedVersionsPerProperty["publicationYear"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.VersionDate.HasValue) + writer.WritePropertyName("publicationYear"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("versionIdentifier"u8); - writer.WriteStringValue(referenceSource.VersionIdentifier); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ReferenceSource for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "publishedin": + if(!AllowedVersionsPerProperty["publishedIn"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.Actor.HasValue) + writer.WritePropertyName("publishedIn"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.Actor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referenceSource.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "publisher": + if(!AllowedVersionsPerProperty["publisher"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(referenceSource.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in referenceSource.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("publisher"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referenceSource.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referenceSource.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in referenceSource.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in referenceSource.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referenceSource.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referenceSource.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referenceSource.IsDeprecated); - writer.WritePropertyName("language"u8); - writer.WriteStringValue(referenceSource.Language); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(referenceSource.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referenceSource.Name); - writer.WritePropertyName("publicationYear"u8); + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.PublicationYear.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteNumberValue(referenceSource.PublicationYear.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("publishedIn"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.PublishedIn.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.PublishedIn.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("publisher"u8); + break; + case "versiondate": + if(!AllowedVersionsPerProperty["versionDate"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.Publisher.HasValue) + writer.WritePropertyName("versionDate"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.Publisher.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referenceSource.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referenceSource.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(referenceSource.ThingPreference); - writer.WritePropertyName("versionDate"u8); + break; + case "versionidentifier": + if(!AllowedVersionsPerProperty["versionIdentifier"].Contains(requestedVersion)) + { + return; + } - if(referenceSource.VersionDate.HasValue) + writer.WritePropertyName("versionIdentifier"u8); + + if(value != null) { - writer.WriteStringValue(referenceSource.VersionDate.Value.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("versionIdentifier"u8); - writer.WriteStringValue(referenceSource.VersionIdentifier); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ReferenceSource"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "language", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "publicationYear", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "publishedIn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "publisher", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "versionDate", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "versionIdentifier", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs index 48553ff25..36b9ef62a 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReferencerRuleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,231 +51,500 @@ namespace CDP4JsonSerializer public class ReferencerRuleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ReferencerRule referencerRule) + { + throw new ArgumentException("The thing shall be a ReferencerRule", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ReferencerRule since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ReferencerRule for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); - if(value is IEnumerable objectListAlias) + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(referencedCategoryItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ReferencerRule for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(referencedCategoryItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ReferencerRule for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referencedCategoryItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referencerRule.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ReferencerRule for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(referencerRule.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(referencerRule.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(referencerRule.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(referencerRule.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(referencerRule.IsDeprecated); + writer.WritePropertyName("maxReferenced"u8); + writer.WriteNumberValue(referencerRule.MaxReferenced); + writer.WritePropertyName("minReferenced"u8); + writer.WriteNumberValue(referencerRule.MinReferenced); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(referencerRule.Name); + writer.WriteStartArray("referencedCategory"u8); + + foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referencedCategoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("referencingCategory"u8); + writer.WriteStringValue(referencerRule.ReferencingCategory); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(referencerRule.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(referencerRule.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(referencerRule.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -292,15 +562,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "maxreferenced": - var allowedVersionsForMaxReferenced = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMaxReferenced.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["maxReferenced"].Contains(requestedVersion)) { return; } @@ -318,15 +580,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "minreferenced": - var allowedVersionsForMinReferenced = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForMinReferenced.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["minReferenced"].Contains(requestedVersion)) { return; } @@ -344,14 +598,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -369,15 +616,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -395,15 +634,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencedcategory": - var allowedVersionsForReferencedCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencedCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencedCategory"].Contains(requestedVersion)) { return; } @@ -421,15 +652,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "referencingcategory": - var allowedVersionsForReferencingCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencingCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencingCategory"].Contains(requestedVersion)) { return; } @@ -447,15 +670,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -473,15 +688,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -499,13 +706,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -528,317 +729,29 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ReferencerRule referencerRule) - { - throw new ArgumentException("The thing shall be a ReferencerRule", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ReferencerRule since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referencerRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referencerRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referencerRule.IsDeprecated); - writer.WritePropertyName("maxReferenced"u8); - writer.WriteNumberValue(referencerRule.MaxReferenced); - writer.WritePropertyName("minReferenced"u8); - writer.WriteNumberValue(referencerRule.MinReferenced); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referencerRule.Name); - writer.WriteStartArray("referencedCategory"u8); - - foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referencedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("referencingCategory"u8); - writer.WriteStringValue(referencerRule.ReferencingCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referencerRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referencerRule.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referencerRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referencerRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referencerRule.IsDeprecated); - writer.WritePropertyName("maxReferenced"u8); - writer.WriteNumberValue(referencerRule.MaxReferenced); - writer.WritePropertyName("minReferenced"u8); - writer.WriteNumberValue(referencerRule.MinReferenced); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referencerRule.Name); - writer.WriteStartArray("referencedCategory"u8); - - foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referencedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("referencingCategory"u8); - writer.WriteStringValue(referencerRule.ReferencingCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referencerRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referencerRule.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referencerRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referencerRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referencerRule.IsDeprecated); - writer.WritePropertyName("maxReferenced"u8); - writer.WriteNumberValue(referencerRule.MaxReferenced); - writer.WritePropertyName("minReferenced"u8); - writer.WriteNumberValue(referencerRule.MinReferenced); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referencerRule.Name); - writer.WriteStartArray("referencedCategory"u8); - - foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referencedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("referencingCategory"u8); - writer.WriteStringValue(referencerRule.ReferencingCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referencerRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referencerRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(referencerRule.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ReferencerRule for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(referencerRule.Actor.HasValue) - { - writer.WriteStringValue(referencerRule.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in referencerRule.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(referencerRule.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in referencerRule.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in referencerRule.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in referencerRule.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in referencerRule.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(referencerRule.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(referencerRule.IsDeprecated); - writer.WritePropertyName("maxReferenced"u8); - writer.WriteNumberValue(referencerRule.MaxReferenced); - writer.WritePropertyName("minReferenced"u8); - writer.WriteNumberValue(referencerRule.MinReferenced); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(referencerRule.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(referencerRule.Name); - writer.WriteStartArray("referencedCategory"u8); - - foreach(var referencedCategoryItem in referencerRule.ReferencedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referencedCategoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("referencingCategory"u8); - writer.WriteStringValue(referencerRule.ReferencingCategory); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(referencerRule.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(referencerRule.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(referencerRule.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "maxReferenced", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "minReferenced", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referencingCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs index c7a9b5bf9..dd52a2064 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationalExpressionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,213 @@ namespace CDP4JsonSerializer /// public class RelationalExpressionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not RelationalExpression relationalExpression) + { + throw new ArgumentException("The thing shall be a RelationalExpression", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of RelationalExpression since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RelationalExpression for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RelationalExpression for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RelationalExpression for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationalExpression.ThingPreference); + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RelationalExpression for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(relationalExpression.Actor.HasValue) + { + writer.WriteStringValue(relationalExpression.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationalExpression.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationalExpression.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationalExpression.ParameterType); + writer.WritePropertyName("relationalOperator"u8); + writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationalExpression.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationalExpression.Scale.HasValue) + { + writer.WriteStringValue(relationalExpression.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationalExpression.ThingPreference); + writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +264,7 @@ public class RelationalExpressionSerializer : BaseThingSerializer, IThingSeriali /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +272,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +290,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +308,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +326,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +344,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +362,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +380,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -239,15 +398,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "relationaloperator": - var allowedVersionsForRelationalOperator = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelationalOperator.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relationalOperator"].Contains(requestedVersion)) { return; } @@ -265,15 +416,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,15 +434,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -317,13 +452,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -341,15 +470,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -362,205 +483,23 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not RelationalExpression relationalExpression) - { - throw new ArgumentException("The thing shall be a RelationalExpression", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RelationalExpression since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationalExpression.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationalExpression.Iid); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationalExpression.ParameterType); - writer.WritePropertyName("relationalOperator"u8); - writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationalExpression.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationalExpression.Scale.HasValue) - { - writer.WriteStringValue(relationalExpression.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationalExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationalExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationalExpression.ParameterType); - writer.WritePropertyName("relationalOperator"u8); - writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationalExpression.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationalExpression.Scale.HasValue) - { - writer.WriteStringValue(relationalExpression.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationalExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationalExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationalExpression.ParameterType); - writer.WritePropertyName("relationalOperator"u8); - writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationalExpression.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationalExpression.Scale.HasValue) - { - writer.WriteStringValue(relationalExpression.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(relationalExpression.ThingPreference); - writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RelationalExpression for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(relationalExpression.Actor.HasValue) - { - writer.WriteStringValue(relationalExpression.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationalExpression.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationalExpression.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationalExpression.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationalExpression.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationalExpression.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationalExpression.ParameterType); - writer.WritePropertyName("relationalOperator"u8); - writer.WriteStringValue(relationalExpression.RelationalOperator.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationalExpression.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationalExpression.Scale.HasValue) - { - writer.WriteStringValue(relationalExpression.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(relationalExpression.ThingPreference); - writer.WriteString("value"u8, relationalExpression.Value.ToJsonString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "relationalOperator", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs index a7653761d..751c35b7c 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RelationshipParameterValueSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,182 @@ namespace CDP4JsonSerializer /// public class RelationshipParameterValueSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not RelationshipParameterValue relationshipParameterValue) + { + throw new ArgumentException("The thing shall be a RelationshipParameterValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of RelationshipParameterValue since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RelationshipParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RelationshipParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationshipParameterValue.ThingPreference); + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RelationshipParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(relationshipParameterValue.Actor.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(relationshipParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(relationshipParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(relationshipParameterValue.Scale.HasValue) + { + writer.WriteStringValue(relationshipParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(relationshipParameterValue.ThingPreference); + writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +233,7 @@ public class RelationshipParameterValueSerializer : BaseThingSerializer, IThingS /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +241,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +259,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +277,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +295,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +313,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -186,14 +331,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -211,14 +349,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -236,14 +367,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -261,14 +385,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -286,13 +403,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -310,14 +421,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -330,174 +434,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not RelationshipParameterValue relationshipParameterValue) - { - throw new ArgumentException("The thing shall be a RelationshipParameterValue", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RelationshipParameterValue since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationshipParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationshipParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationshipParameterValue.Scale.HasValue) - { - writer.WriteStringValue(relationshipParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationshipParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationshipParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationshipParameterValue.Scale.HasValue) - { - writer.WriteStringValue(relationshipParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(relationshipParameterValue.ThingPreference); - writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RelationshipParameterValue for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(relationshipParameterValue.Actor.HasValue) - { - writer.WriteStringValue(relationshipParameterValue.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(relationshipParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in relationshipParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in relationshipParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(relationshipParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(relationshipParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(relationshipParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(relationshipParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(relationshipParameterValue.Scale.HasValue) - { - writer.WriteStringValue(relationshipParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(relationshipParameterValue.ThingPreference); - writer.WriteString("value"u8, relationshipParameterValue.Value.ToJsonString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs index c9ae82ee9..8aabd337b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForDeviationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,305 +51,382 @@ namespace CDP4JsonSerializer public class RequestForDeviationSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RequestForDeviation requestForDeviation) + { + throw new ArgumentException("The thing shall be a RequestForDeviation", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RequestForDeviation since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForDeviation for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForDeviation for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForDeviation.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForDeviation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requestForDeviation.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(requestForDeviation.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WriteStartArray("discussion"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForDeviation.Author); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDiscussion) + foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForDeviation.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForDeviation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForDeviation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForDeviation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForDeviation.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(requestForDeviation.PrimaryAnnotatedThing.HasValue) { - return; + writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("relatedThing"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(relatedThingItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForDeviation.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForDeviation.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForDeviation.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForDeviation.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForDeviation.Title); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -360,24 +438,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("author"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -385,24 +474,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -410,24 +510,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,24 +528,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -460,49 +546,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("relatedThing"u8); - - if(value is IEnumerable objectListRelatedThing) - { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -510,74 +564,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) { - writer.WriteStringValue((string)value); + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListSourceAnnotation) + if(value is IEnumerable objectListExcludedPerson) { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(sourceAnnotationItem); + writer.WriteStringValue(excludedPersonItem); } } writer.WriteEndArray(); break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("status"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -585,19 +636,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -609,24 +654,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -634,345 +672,202 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForDeviation"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RequestForDeviation requestForDeviation) - { - throw new ArgumentException("The thing shall be a RequestForDeviation", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RequestForDeviation since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForDeviation.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForDeviation.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForDeviation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForDeviation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForDeviation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForDeviation.Owner); writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + + if(value != null) { - writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForDeviation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForDeviation.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForDeviation.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForDeviation.Title); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForDeviation.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForDeviation.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForDeviation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForDeviation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForDeviation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForDeviation.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForDeviation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForDeviation.ShortName); writer.WriteStartArray("sourceAnnotation"u8); - foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForDeviation.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requestForDeviation.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForDeviation.Title); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForDeviation for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) + { + return; + } - if(requestForDeviation.Actor.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(requestForDeviation.Actor.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForDeviation.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForDeviation.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForDeviation.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForDeviation.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForDeviation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForDeviation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForDeviation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForDeviation.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForDeviation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForDeviation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForDeviation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForDeviation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForDeviation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForDeviation.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForDeviation.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(requestForDeviation.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForDeviation.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForDeviation.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForDeviation.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in requestForDeviation.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForDeviation.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requestForDeviation.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForDeviation.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForDeviation"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs index 322fed874..e083024a7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequestForWaiverSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,305 +51,382 @@ namespace CDP4JsonSerializer public class RequestForWaiverSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RequestForWaiver requestForWaiver) + { + throw new ArgumentException("The thing shall be a RequestForWaiver", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RequestForWaiver since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForWaiver for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(value is IEnumerable objectListCategory) + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(sourceAnnotationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForWaiver for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForWaiver.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RequestForWaiver for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requestForWaiver.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(requestForWaiver.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WriteStartArray("discussion"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(requestForWaiver.Author); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDiscussion) + foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(requestForWaiver.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(requestForWaiver.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requestForWaiver.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(requestForWaiver.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requestForWaiver.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(requestForWaiver.PrimaryAnnotatedThing.HasValue) { - return; + writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("relatedThing"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(relatedThingItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requestForWaiver.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requestForWaiver.ShortName); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(requestForWaiver.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requestForWaiver.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(requestForWaiver.Title); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -360,24 +438,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(value is IEnumerable objectListApprovedBy) + { + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(approvedByItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("author"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -385,24 +474,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -410,24 +510,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -435,24 +528,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -460,49 +546,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("relatedThing"u8); - - if(value is IEnumerable objectListRelatedThing) - { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -510,74 +564,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("discussion"u8); + + if(value is IEnumerable objectListDiscussion) { - writer.WriteStringValue((string)value); + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListSourceAnnotation) + if(value is IEnumerable objectListExcludedPerson) { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(sourceAnnotationItem); + writer.WriteStringValue(excludedPersonItem); } } writer.WriteEndArray(); break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("status"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -585,19 +636,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -609,24 +654,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -634,345 +672,202 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForWaiver"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RequestForWaiver requestForWaiver) - { - throw new ArgumentException("The thing shall be a RequestForWaiver", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RequestForWaiver since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForWaiver.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForWaiver.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForWaiver.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForWaiver.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForWaiver.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForWaiver.Owner); writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + + if(value != null) { - writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForWaiver.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForWaiver.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForWaiver.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForWaiver.Title); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForWaiver.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForWaiver.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForWaiver.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForWaiver.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForWaiver.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForWaiver.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForWaiver.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForWaiver.ShortName); writer.WriteStartArray("sourceAnnotation"u8); - foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(sourceAnnotationItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForWaiver.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requestForWaiver.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForWaiver.Title); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RequestForWaiver for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) + { + return; + } - if(requestForWaiver.Actor.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(requestForWaiver.Actor.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in requestForWaiver.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(requestForWaiver.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requestForWaiver.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(requestForWaiver.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requestForWaiver.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(requestForWaiver.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(requestForWaiver.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in requestForWaiver.Discussion.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(discussionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requestForWaiver.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requestForWaiver.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requestForWaiver.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(requestForWaiver.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requestForWaiver.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requestForWaiver.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(requestForWaiver.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(requestForWaiver.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in requestForWaiver.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requestForWaiver.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requestForWaiver.ShortName); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in requestForWaiver.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(requestForWaiver.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requestForWaiver.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(requestForWaiver.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequestForWaiver"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs index 489a7dab0..5edc2e7d7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,365 +51,461 @@ namespace CDP4JsonSerializer public class RequirementSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not Requirement requirement) + { + throw new ArgumentException("The thing shall be a Requirement", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List + Logger.Log(LogLevel.Info, "Skipping serialization of Requirement since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Requirement for Version 1.0.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) { - "1.3.0", - }; + writer.WriteStringValue(categoryItem); + } - if(!allowedVersionsForActor.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requirement.Group.Value); } else { writer.WriteNullValue(); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); - if(value is IEnumerable objectListAlias) + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(parameterValueItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Requirement for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(requirement.Group.Value); } else { writer.WriteNullValue(); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); - if(value is IEnumerable objectListDefinition) + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(parameterValueItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Requirement for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "group": - var allowedVersionsForGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForGroup.Contains(requestedVersion)) + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("group"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requirement.Group.Value); } else { writer.WriteNullValue(); } - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(parameterValueItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("parametricConstraint"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(parametricConstraintItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirement.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Requirement for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirement.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requirement.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirement.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("group"u8); + + if(requirement.Group.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(requirement.Group.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirement.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirement.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirement.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirement.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(parameterValueItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("parametricConstraint"u8); + + foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(parametricConstraintItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirement.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirement.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirement.ThingPreference); break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -420,77 +517,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "parametervalue": - var allowedVersionsForParameterValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("parameterValue"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListParameterValue) + if(value is IEnumerable objectListAlias) { - foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterValueItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "parametricconstraint": - var allowedVersionsForParametricConstraint = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParametricConstraint.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("parametricConstraint"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListParametricConstraint) + if(value is IEnumerable objectListCategory) { - foreach(var parametricConstraintItem in objectListParametricConstraint.OfType().OrderBy(x => x, this.OrderedItemComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteOrderedItem(parametricConstraintItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -498,49 +571,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "group": + if(!AllowedVersionsPerProperty["group"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("group"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -548,415 +643,234 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Requirement"); - } - } + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Requirement requirement) - { - throw new ArgumentException("The thing shall be a Requirement", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Requirement since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(categoryItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirement.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("group"u8); - - if(requirement.Group.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(requirement.Group.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirement.Iid); writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirement.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirement.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirement.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(parameterValueItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("parametricConstraint"u8); - - foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(parametricConstraintItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirement.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirement.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirement.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("group"u8); - - if(requirement.Group.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(requirement.Group.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirement.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirement.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirement.Name); writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirement.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(parameterValueItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("parametricConstraint"u8); - - foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + else { - writer.WriteOrderedItem(parametricConstraintItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirement.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirement.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) + case "parametervalue": + if(!AllowedVersionsPerProperty["parameterValue"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("parameterValue"u8); - foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterValue) { - writer.WriteStringValue(categoryItem); + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirement.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "parametricconstraint": + if(!AllowedVersionsPerProperty["parametricConstraint"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("parametricConstraint"u8); - foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParametricConstraint) { - writer.WriteStringValue(excludedDomainItem); + foreach(var parametricConstraintItem in objectListParametricConstraint.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(parametricConstraintItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("group"u8); - - if(requirement.Group.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(requirement.Group.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirement.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirement.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirement.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirement.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("parametricConstraint"u8); - - foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteOrderedItem(parametricConstraintItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirement.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirement.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirement.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Requirement for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(requirement.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(requirement.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirement.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requirement.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirement.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirement.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirement.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirement.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("group"u8); - - if(requirement.Group.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(requirement.Group.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirement.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirement.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirement.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirement.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirement.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirement.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirement.ParameterValue.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("parametricConstraint"u8); - - foreach(var parametricConstraintItem in requirement.ParametricConstraint.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(parametricConstraintItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirement.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirement.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirement.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Requirement"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "group", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValue", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parametricConstraint", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs index 21e384c1f..cd791bb98 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsContainerParameterValueSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,182 @@ namespace CDP4JsonSerializer /// public class RequirementsContainerParameterValueSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not RequirementsContainerParameterValue requirementsContainerParameterValue) + { + throw new ArgumentException("The thing shall be a RequirementsContainerParameterValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsContainerParameterValue since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsContainerParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsContainerParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsContainerParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirementsContainerParameterValue.Actor.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsContainerParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(requirementsContainerParameterValue.Scale.HasValue) + { + writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); + writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +233,7 @@ public class RequirementsContainerParameterValueSerializer : BaseThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +241,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +259,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +277,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +295,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +313,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -186,14 +331,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -211,14 +349,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -236,14 +367,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -261,14 +385,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -286,13 +403,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -310,14 +421,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -330,174 +434,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not RequirementsContainerParameterValue requirementsContainerParameterValue) - { - throw new ArgumentException("The thing shall be a RequirementsContainerParameterValue", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsContainerParameterValue since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsContainerParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(requirementsContainerParameterValue.Scale.HasValue) - { - writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsContainerParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(requirementsContainerParameterValue.Scale.HasValue) - { - writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); - writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsContainerParameterValue for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(requirementsContainerParameterValue.Actor.HasValue) - { - writer.WriteStringValue(requirementsContainerParameterValue.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsContainerParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsContainerParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsContainerParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsContainerParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(requirementsContainerParameterValue.Scale.HasValue) - { - writer.WriteStringValue(requirementsContainerParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsContainerParameterValue.ThingPreference); - writer.WriteString("value"u8, requirementsContainerParameterValue.Value.ToJsonString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs index 496d84ec6..31cc56d6e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsGroupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,529 +51,274 @@ namespace CDP4JsonSerializer public class RequirementsGroupSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RequirementsGroup requirementsGroup) + { + throw new ArgumentException("The thing shall be a RequirementsGroup", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsGroup since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsGroup for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(groupItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); - if(value is IEnumerable objectListDefinition) + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(groupItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsGroup.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsGroup.Owner); + writer.WriteStartArray("parameterValue"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(parameterValueItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsGroup.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "group": - var allowedVersionsForGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForGroup.Contains(requestedVersion)) + foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("group"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListGroup) + foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(groupItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("group"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(groupItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(requirementsGroup.Name); writer.WritePropertyName("owner"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "parametervalue": - var allowedVersionsForParameterValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValue.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(requirementsGroup.Owner); writer.WriteStartArray("parameterValue"u8); - if(value is IEnumerable objectListParameterValue) - { - foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterValueItem); - } - } - - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterValueItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsGroup.RevisionNumber); writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WriteStringValue(requirementsGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsGroup.ThingPreference); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + if(requirementsGroup.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(requirementsGroup.Actor.Value); } else { writer.WriteNullValue(); } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsGroup"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RequirementsGroup requirementsGroup) - { - throw new ArgumentException("The thing shall be a RequirementsGroup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsGroup since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); - - foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(groupItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsGroup.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsGroup.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsGroup.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsGroup.ShortName); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.1.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) @@ -581,6 +327,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("category"u8); foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) @@ -589,6 +336,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -599,6 +347,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -607,6 +356,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -615,6 +365,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("group"u8); foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) @@ -623,6 +374,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -631,6 +383,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(requirementsGroup.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -647,194 +400,369 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(requirementsGroup.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(requirementsGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsGroup.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.2.0"); - writer.WriteStartArray("alias"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); + writer.WriteStartArray("alias"u8); - foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(groupItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsGroup.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsGroup.Owner); - writer.WriteStartArray("parameterValue"u8); + writer.WriteStartArray("category"u8); - foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListCategory) { - writer.WriteStringValue(parameterValueItem); + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsGroup.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsGroup.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsGroup for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } - if(requirementsGroup.Actor.HasValue) + writer.WritePropertyName("classKind"u8); + + if(value != null) { - writer.WriteStringValue(requirementsGroup.Actor.Value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsGroup.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("definition"u8); - foreach(var categoryItem in requirementsGroup.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(categoryItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsGroup.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in requirementsGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in requirementsGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "group": + if(!AllowedVersionsPerProperty["group"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("group"u8); - foreach(var groupItem in requirementsGroup.Group.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGroup) { - writer.WriteStringValue(groupItem); + foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in requirementsGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsGroup.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsGroup.Name); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsGroup.Owner); - writer.WriteStartArray("parameterValue"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var parameterValueItem in requirementsGroup.ParameterValue.OrderBy(x => x, this.GuidComparer)) + break; + case "parametervalue": + if(!AllowedVersionsPerProperty["parameterValue"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterValueItem); + return; } + writer.WriteStartArray("parameterValue"u8); + + if(value is IEnumerable objectListParameterValue) + { + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } + } + writer.WriteEndArray(); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsGroup.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsGroup.ShortName); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsGroup.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsGroup"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "group", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs index 3f9c5533f..a237a7fb8 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RequirementsSpecificationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,364 +51,435 @@ namespace CDP4JsonSerializer public class RequirementsSpecificationSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RequirementsSpecification requirementsSpecification) + { + throw new ArgumentException("The thing shall be a RequirementsSpecification", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsSpecification since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsSpecification for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(groupItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("requirement"u8); - if(value is IEnumerable objectListAlias) + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(requirementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsSpecification for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(groupItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(parameterValueItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("requirement"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(requirementItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsSpecification for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "group": - var allowedVersionsForGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForGroup.Contains(requestedVersion)) + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("group"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListGroup) + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(groupItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(groupItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(parameterValueItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("requirement"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requirementItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsSpecification.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RequirementsSpecification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(requirementsSpecification.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(requirementsSpecification.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("group"u8); + + foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(groupItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(requirementsSpecification.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(requirementsSpecification.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(requirementsSpecification.Owner); + writer.WriteStartArray("parameterValue"u8); + + foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(parameterValueItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(requirementItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(requirementsSpecification.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(requirementsSpecification.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(requirementsSpecification.ThingPreference); break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -419,76 +491,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "parametervalue": - var allowedVersionsForParameterValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterValue.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("parameterValue"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListParameterValue) + if(value is IEnumerable objectListAlias) { - foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(parameterValueItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "requirement": - var allowedVersionsForRequirement = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRequirement.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("requirement"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListRequirement) + if(value is IEnumerable objectListCategory) { - foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(requirementItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -496,437 +545,306 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue((string)value); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - else + + writer.WriteEndArray(); + break; + case "group": + if(!AllowedVersionsPerProperty["group"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsSpecification"); - } - } + writer.WriteStartArray("group"u8); - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RequirementsSpecification requirementsSpecification) - { - throw new ArgumentException("The thing shall be a RequirementsSpecification", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RequirementsSpecification since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGroup) { - writer.WriteStringValue(aliasItem); + foreach(var groupItem in objectListGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(groupItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(groupItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsSpecification.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsSpecification.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsSpecification.Owner); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(requirementItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsSpecification.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsSpecification.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); - - foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(groupItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsSpecification.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsSpecification.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsSpecification.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(parameterValueItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(requirementItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsSpecification.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsSpecification.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("owner"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "parametervalue": + if(!AllowedVersionsPerProperty["parameterValue"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); + writer.WriteStartArray("parameterValue"u8); - foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParameterValue) { - writer.WriteStringValue(groupItem); + foreach(var parameterValueItem in objectListParameterValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterValueItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "requirement": + if(!AllowedVersionsPerProperty["requirement"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsSpecification.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsSpecification.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsSpecification.Owner); - writer.WriteStartArray("parameterValue"u8); + writer.WriteStartArray("requirement"u8); - foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRequirement) { - writer.WriteStringValue(parameterValueItem); + foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(requirementItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsSpecification.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsSpecification.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsSpecification.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RequirementsSpecification for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(requirementsSpecification.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(requirementsSpecification.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in requirementsSpecification.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in requirementsSpecification.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(requirementsSpecification.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in requirementsSpecification.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in requirementsSpecification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in requirementsSpecification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("group"u8); - - foreach(var groupItem in requirementsSpecification.Group.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(groupItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in requirementsSpecification.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(requirementsSpecification.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(requirementsSpecification.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(requirementsSpecification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(requirementsSpecification.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(requirementsSpecification.Owner); - writer.WriteStartArray("parameterValue"u8); - - foreach(var parameterValueItem in requirementsSpecification.ParameterValue.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(parameterValueItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in requirementsSpecification.Requirement.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(requirementItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(requirementsSpecification.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(requirementsSpecification.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(requirementsSpecification.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RequirementsSpecification"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "group", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "requirement", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs index ae3bf64b7..bd78f1344 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ReviewItemDiscrepancySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,305 +51,445 @@ namespace CDP4JsonSerializer public class ReviewItemDiscrepancySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not ReviewItemDiscrepancy reviewItemDiscrepancy) + { + throw new ArgumentException("The thing shall be a ReviewItemDiscrepancy", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.1.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of ReviewItemDiscrepancy since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ReviewItemDiscrepancy for Version 1.1.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "approvedby": - var allowedVersionsForApprovedBy = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForApprovedBy.Contains(requestedVersion)) + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(discussionItem); } - writer.WriteStartArray("approvedBy"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListApprovedBy) + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); - if(value is IEnumerable objectListCategory) + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(solutionItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); break; - case "classification": - var allowedVersionsForClassification = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ReviewItemDiscrepancy for Version 1.2.0"); + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForClassification.Contains(requestedVersion)) + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } - writer.WritePropertyName("classification"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(discussionItem); } - break; - case "classkind": - var allowedVersionsForClassKind = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); + + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("relatedThing"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(relatedThingItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); + + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(solutionItem); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("sourceAnnotation"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(sourceAnnotationItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ReviewItemDiscrepancy for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(reviewItemDiscrepancy.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(reviewItemDiscrepancy.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("approvedBy"u8); - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(approvedByItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Author); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classification"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WriteStartArray("discussion"u8); - if(value is IEnumerable objectListDiscussion) + foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) { - foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } + writer.WriteStringValue(discussionItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Owner); + writer.WritePropertyName("primaryAnnotatedThing"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) { - return; + writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("relatedThing"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ShortName); + writer.WriteStartArray("solution"u8); + + foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("sourceAnnotation"u8); + + foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("status"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); + writer.WritePropertyName("title"u8); + writer.WriteStringValue(reviewItemDiscrepancy.Title); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteNullValue(); + } - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + break; + case "approvedby": + if(!AllowedVersionsPerProperty["approvedBy"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("approvedBy"u8); - if(value is IEnumerable objectListExcludedPerson) + if(value is IEnumerable objectListApprovedBy) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var approvedByItem in objectListApprovedBy.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(approvedByItem); } } writer.WriteEndArray(); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("author"u8); if(value != null) { @@ -360,24 +501,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classification": + if(!AllowedVersionsPerProperty["classification"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); + writer.WritePropertyName("classification"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((AnnotationClassificationKind)value).ToString()); } else { @@ -385,24 +537,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -410,24 +555,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("owner"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue((string)value); } else { @@ -435,24 +573,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -460,49 +591,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "relatedthing": - var allowedVersionsForRelatedThing = new List + case "discussion": + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("discussion"u8); - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(value is IEnumerable objectListDiscussion) + { + foreach(var discussionItem in objectListDiscussion.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("relatedThing"u8); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListRelatedThing) + if(value is IEnumerable objectListExcludedDomain) { - foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(relatedThingItem); + writer.WriteStringValue(excludedDomainItem); } } writer.WriteEndArray(); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -510,20 +663,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("languageCode"u8); if(value != null) { @@ -535,74 +681,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "solution": - var allowedVersionsForSolution = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSolution.Contains(requestedVersion)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("solution"u8); - - if(value is IEnumerable objectListSolution) - { - foreach(var solutionItem in objectListSolution.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(solutionItem); - } - } - - writer.WriteEndArray(); - break; - case "sourceannotation": - var allowedVersionsForSourceAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSourceAnnotation.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("sourceAnnotation"u8); - - if(value is IEnumerable objectListSourceAnnotation) - { - foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - } - - writer.WriteEndArray(); - break; - case "status": - var allowedVersionsForStatus = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("status"u8); + writer.WritePropertyName("modifiedOn"u8); if(value != null) { - writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -610,23 +699,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("owner"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -634,24 +717,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "title": - var allowedVersionsForTitle = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForTitle.Contains(requestedVersion)) + case "primaryannotatedthing": + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("title"u8); + writer.WritePropertyName("primaryAnnotatedThing"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -659,369 +735,185 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ReviewItemDiscrepancy"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ReviewItemDiscrepancy reviewItemDiscrepancy) - { - throw new ArgumentException("The thing shall be a ReviewItemDiscrepancy", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ReviewItemDiscrepancy since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.1.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) + case "relatedthing": + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("relatedThing"u8); - foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRelatedThing) { - writer.WriteStringValue(excludedDomainItem); + foreach(var relatedThingItem in objectListRelatedThing.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(relatedThingItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ShortName); - writer.WriteStartArray("solution"u8); - - foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(solutionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(sourceAnnotationItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Title); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.2.0"); - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) + case "solution": + if(!AllowedVersionsPerProperty["solution"].Contains(requestedVersion)) { - writer.WriteStringValue(approvedByItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Author); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("solution"u8); - foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSolution) { - writer.WriteStringValue(categoryItem); + foreach(var solutionItem in objectListSolution.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(solutionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) + break; + case "sourceannotation": + if(!AllowedVersionsPerProperty["sourceAnnotation"].Contains(requestedVersion)) { - writer.WriteStringValue(discussionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("sourceAnnotation"u8); - foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSourceAnnotation) { - writer.WriteStringValue(excludedDomainItem); + foreach(var sourceAnnotationItem in objectListSourceAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(sourceAnnotationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "status": + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("status"u8); + + if(value != null) { - writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + writer.WriteStringValue(((AnnotationStatusKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ShortName); - writer.WriteStartArray("solution"u8); - - foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(solutionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(sourceAnnotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Title); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ReviewItemDiscrepancy for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(reviewItemDiscrepancy.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(reviewItemDiscrepancy.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("approvedBy"u8); - - foreach(var approvedByItem in reviewItemDiscrepancy.ApprovedBy.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(approvedByItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Author); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in reviewItemDiscrepancy.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classification"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Classification.ToString()); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in reviewItemDiscrepancy.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in reviewItemDiscrepancy.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in reviewItemDiscrepancy.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "title": + if(!AllowedVersionsPerProperty["title"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(reviewItemDiscrepancy.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Owner); - writer.WritePropertyName("primaryAnnotatedThing"u8); - - if(reviewItemDiscrepancy.PrimaryAnnotatedThing.HasValue) + writer.WritePropertyName("title"u8); + + if(value != null) { - writer.WriteStringValue(reviewItemDiscrepancy.PrimaryAnnotatedThing.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in reviewItemDiscrepancy.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(reviewItemDiscrepancy.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ShortName); - writer.WriteStartArray("solution"u8); - - foreach(var solutionItem in reviewItemDiscrepancy.Solution.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(solutionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("sourceAnnotation"u8); - - foreach(var sourceAnnotationItem in reviewItemDiscrepancy.SourceAnnotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(sourceAnnotationItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(reviewItemDiscrepancy.ThingPreference); - writer.WritePropertyName("title"u8); - writer.WriteStringValue(reviewItemDiscrepancy.Title); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ReviewItemDiscrepancy"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "approvedBy", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classification", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "solution", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "sourceAnnotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "title", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs index 4da2b357e..5cf08a6b8 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleVerificationListSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,317 +51,341 @@ namespace CDP4JsonSerializer public class RuleVerificationListSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not RuleVerificationList ruleVerificationList) + { + throw new ArgumentException("The thing shall be a RuleVerificationList", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of RuleVerificationList since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RuleVerificationList for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); - if(value is IEnumerable objectListAlias) + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteOrderedItem(ruleVerificationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RuleVerificationList for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListDefinition) + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteOrderedItem(ruleVerificationItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RuleVerificationList for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(ruleVerificationItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleVerificationList.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RuleVerificationList for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ruleVerificationList.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(ruleVerificationList.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "owner": - var allowedVersionsForOwner = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForOwner.Contains(requestedVersion)) + foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("owner"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleVerificationList.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(ruleVerificationList.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(ruleVerificationList.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleVerificationList.RevisionNumber); + writer.WriteStartArray("ruleVerification"u8); + + foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteNullValue(); + writer.WriteOrderedItem(ruleVerificationItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(ruleVerificationList.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleVerificationList.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -368,51 +393,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "ruleverification": - var allowedVersionsForRuleVerification = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRuleVerification.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("ruleVerification"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListRuleVerification) + if(value is IEnumerable objectListAlias) { - foreach(var ruleVerificationItem in objectListRuleVerification.OfType().OrderBy(x => x, this.OrderedItemComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteOrderedItem(ruleVerificationItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -420,323 +429,248 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteNullValue(); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + + writer.WriteEndArray(); break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the RuleVerificationList"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not RuleVerificationList ruleVerificationList) - { - throw new ArgumentException("The thing shall be a RuleVerificationList", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RuleVerificationList since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(definitionItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleVerificationList.Iid); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ruleVerificationList.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(ruleVerificationList.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleVerificationList.RevisionNumber); - writer.WriteStartArray("ruleVerification"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteOrderedItem(ruleVerificationItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ruleVerificationList.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(definitionItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleVerificationList.Iid); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ruleVerificationList.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(ruleVerificationList.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleVerificationList.RevisionNumber); - writer.WriteStartArray("ruleVerification"u8); - - foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(ruleVerificationItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ruleVerificationList.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(aliasItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "owner": + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleVerificationList.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ruleVerificationList.Name); writer.WritePropertyName("owner"u8); - writer.WriteStringValue(ruleVerificationList.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleVerificationList.RevisionNumber); - writer.WriteStartArray("ruleVerification"u8); - - foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + + if(value != null) { - writer.WriteOrderedItem(ruleVerificationItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ruleVerificationList.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ruleVerificationList.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RuleVerificationList for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(ruleVerificationList.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(ruleVerificationList.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in ruleVerificationList.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "ruleverification": + if(!AllowedVersionsPerProperty["ruleVerification"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleVerificationList.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("ruleVerification"u8); - foreach(var definitionItem in ruleVerificationList.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRuleVerification) { - writer.WriteStringValue(definitionItem); + foreach(var ruleVerificationItem in objectListRuleVerification.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(ruleVerificationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleVerificationList.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleVerificationList.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in ruleVerificationList.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleVerificationList.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleVerificationList.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(ruleVerificationList.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(ruleVerificationList.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleVerificationList.RevisionNumber); - writer.WriteStartArray("ruleVerification"u8); - - foreach(var ruleVerificationItem in ruleVerificationList.RuleVerification.OrderBy(x => x, this.OrderedItemComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteOrderedItem(ruleVerificationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(ruleVerificationList.ShortName); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ruleVerificationList.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the RuleVerificationList"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "ruleVerification", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs index e7f25e745..a37d9bcd0 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/RuleViolationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,193 @@ namespace CDP4JsonSerializer /// public class RuleViolationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not RuleViolation ruleViolation) + { + throw new ArgumentException("The thing shall be a RuleViolation", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of RuleViolation since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing RuleViolation for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing RuleViolation for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing RuleViolation for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleViolation.ThingPreference); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing RuleViolation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(ruleViolation.Actor.HasValue) + { + writer.WriteStringValue(ruleViolation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(ruleViolation.ClassKind.ToString()); + writer.WritePropertyName("description"u8); + writer.WriteStringValue(ruleViolation.Description); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(ruleViolation.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(ruleViolation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(ruleViolation.ThingPreference); + writer.WriteStartArray("violatingThing"u8); + + foreach(var violatingThingItem in ruleViolation.ViolatingThing) + { + writer.WriteStringValue(violatingThingItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +244,7 @@ public class RuleViolationSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +252,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +270,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,15 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "description": - var allowedVersionsForDescription = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDescription.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["description"].Contains(requestedVersion)) { return; } @@ -138,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -163,14 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -188,15 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +378,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -265,13 +396,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -289,15 +414,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "violatingthing": - var allowedVersionsForViolatingThing = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForViolatingThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["violatingThing"].Contains(requestedVersion)) { return; } @@ -320,181 +437,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not RuleViolation ruleViolation) - { - throw new ArgumentException("The thing shall be a RuleViolation", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of RuleViolation since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleViolation.ClassKind.ToString()); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(ruleViolation.Description); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleViolation.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleViolation.RevisionNumber); - writer.WriteStartArray("violatingThing"u8); - - foreach(var violatingThingItem in ruleViolation.ViolatingThing) - { - writer.WriteStringValue(violatingThingItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleViolation.ClassKind.ToString()); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(ruleViolation.Description); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleViolation.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleViolation.RevisionNumber); - writer.WriteStartArray("violatingThing"u8); - - foreach(var violatingThingItem in ruleViolation.ViolatingThing) - { - writer.WriteStringValue(violatingThingItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleViolation.ClassKind.ToString()); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(ruleViolation.Description); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleViolation.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleViolation.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ruleViolation.ThingPreference); - writer.WriteStartArray("violatingThing"u8); - - foreach(var violatingThingItem in ruleViolation.ViolatingThing) - { - writer.WriteStringValue(violatingThingItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing RuleViolation for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(ruleViolation.Actor.HasValue) - { - writer.WriteStringValue(ruleViolation.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(ruleViolation.ClassKind.ToString()); - writer.WritePropertyName("description"u8); - writer.WriteStringValue(ruleViolation.Description); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in ruleViolation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in ruleViolation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(ruleViolation.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(ruleViolation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(ruleViolation.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(ruleViolation.ThingPreference); - writer.WriteStartArray("violatingThing"u8); - - foreach(var violatingThingItem in ruleViolation.ViolatingThing) - { - writer.WriteStringValue(violatingThingItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "description", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "violatingThing", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs index 1ba4dc61f..80cb84791 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SampledFunctionParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,259 @@ namespace CDP4JsonSerializer /// public class SampledFunctionParameterTypeSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not SampledFunctionParameterType sampledFunctionParameterType) + { + throw new ArgumentException("The thing shall be a SampledFunctionParameterType", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.2.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SampledFunctionParameterType since Version is below 1.2.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SampledFunctionParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("degreeOfInterpolation"u8); + + if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) + { + writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("dependentParameterType"u8); + + foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dependentParameterTypeItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sampledFunctionParameterType.Iid); + writer.WriteStartArray("independentParameterType"u8); + + foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(independentParameterTypeItem); + } + + writer.WriteEndArray(); + + writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sampledFunctionParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(sampledFunctionParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(sampledFunctionParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SampledFunctionParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(sampledFunctionParameterType.Actor.HasValue) + { + writer.WriteStringValue(sampledFunctionParameterType.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("degreeOfInterpolation"u8); + + if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) + { + writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("dependentParameterType"u8); + + foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(dependentParameterTypeItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sampledFunctionParameterType.Iid); + writer.WriteStartArray("independentParameterType"u8); + + foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(independentParameterTypeItem); + } + + writer.WriteEndArray(); + + writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sampledFunctionParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(sampledFunctionParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(sampledFunctionParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +310,7 @@ public class SampledFunctionParameterTypeSerializer : BaseThingSerializer, IThin /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +318,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,13 +336,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "alias": - var allowedVersionsForAlias = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } @@ -110,13 +354,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "category": - var allowedVersionsForCategory = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -134,13 +372,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -158,13 +390,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "definition": - var allowedVersionsForDefinition = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } @@ -182,13 +408,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "degreeofinterpolation": - var allowedVersionsForDegreeOfInterpolation = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDegreeOfInterpolation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["degreeOfInterpolation"].Contains(requestedVersion)) { return; } @@ -206,13 +426,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "dependentparametertype": - var allowedVersionsForDependentParameterType = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDependentParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["dependentParameterType"].Contains(requestedVersion)) { return; } @@ -229,15 +443,8 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -255,14 +462,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -280,13 +480,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } @@ -304,13 +498,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -328,13 +516,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "independentparametertype": - var allowedVersionsForIndependentParameterType = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIndependentParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["independentParameterType"].Contains(requestedVersion)) { return; } @@ -352,13 +534,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "interpolationperiod": - var allowedVersionsForInterpolationPeriod = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForInterpolationPeriod.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["interpolationPeriod"].Contains(requestedVersion)) { return; } @@ -366,13 +542,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteString("interpolationPeriod"u8, ((ValueArray)value).ToJsonString()); break; case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } @@ -390,14 +560,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -415,13 +578,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -439,13 +596,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -463,13 +614,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -487,13 +632,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "symbol": - var allowedVersionsForSymbol = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { return; } @@ -511,13 +650,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -540,241 +673,31 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not SampledFunctionParameterType sampledFunctionParameterType) - { - throw new ArgumentException("The thing shall be a SampledFunctionParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.2.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SampledFunctionParameterType since Version is below 1.2.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SampledFunctionParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("degreeOfInterpolation"u8); - - if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) - { - writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("dependentParameterType"u8); - - foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(dependentParameterTypeItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(sampledFunctionParameterType.Iid); - writer.WriteStartArray("independentParameterType"u8); - - foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(independentParameterTypeItem); - } - - writer.WriteEndArray(); - writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(sampledFunctionParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(sampledFunctionParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(sampledFunctionParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SampledFunctionParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(sampledFunctionParameterType.Actor.HasValue) - { - writer.WriteStringValue(sampledFunctionParameterType.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in sampledFunctionParameterType.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in sampledFunctionParameterType.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(sampledFunctionParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in sampledFunctionParameterType.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("degreeOfInterpolation"u8); - - if(sampledFunctionParameterType.DegreeOfInterpolation.HasValue) - { - writer.WriteNumberValue(sampledFunctionParameterType.DegreeOfInterpolation.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("dependentParameterType"u8); - - foreach(var dependentParameterTypeItem in sampledFunctionParameterType.DependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(dependentParameterTypeItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in sampledFunctionParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in sampledFunctionParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in sampledFunctionParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(sampledFunctionParameterType.Iid); - writer.WriteStartArray("independentParameterType"u8); - - foreach(var independentParameterTypeItem in sampledFunctionParameterType.IndependentParameterType.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(independentParameterTypeItem); - } - - writer.WriteEndArray(); - writer.WriteString("interpolationPeriod"u8, sampledFunctionParameterType.InterpolationPeriod.ToJsonString()); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(sampledFunctionParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(sampledFunctionParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(sampledFunctionParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(sampledFunctionParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(sampledFunctionParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(sampledFunctionParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(sampledFunctionParameterType.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.2.0", "1.3.0" }}, + { "category", new []{ "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.2.0", "1.3.0" }}, + { "degreeOfInterpolation", new []{ "1.2.0", "1.3.0" }}, + { "dependentParameterType", new []{ "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.2.0", "1.3.0" }}, + { "independentParameterType", new []{ "1.2.0", "1.3.0" }}, + { "interpolationPeriod", new []{ "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs index e65485253..5852aa471 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleReferenceQuantityValueSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class ScaleReferenceQuantityValueSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ScaleReferenceQuantityValue scaleReferenceQuantityValue) + { + throw new ArgumentException("The thing shall be a ScaleReferenceQuantityValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ScaleReferenceQuantityValue since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleReferenceQuantityValue for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleReferenceQuantityValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleReferenceQuantityValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleReferenceQuantityValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(scaleReferenceQuantityValue.Actor.HasValue) + { + writer.WriteStringValue(scaleReferenceQuantityValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Scale); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleReferenceQuantityValue.Value); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class ScaleReferenceQuantityValueSerializer : BaseThingSerializer, IThing /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -265,13 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -289,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ScaleReferenceQuantityValue scaleReferenceQuantityValue) - { - throw new ArgumentException("The thing shall be a ScaleReferenceQuantityValue", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ScaleReferenceQuantityValue since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Scale); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Value); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Scale); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Value); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Scale); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Value); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleReferenceQuantityValue for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(scaleReferenceQuantityValue.Actor.HasValue) - { - writer.WriteStringValue(scaleReferenceQuantityValue.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in scaleReferenceQuantityValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in scaleReferenceQuantityValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(scaleReferenceQuantityValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Scale); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(scaleReferenceQuantityValue.Value); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs index 492f146e2..b1adb3c9b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ScaleValueDefinitionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,424 +51,112 @@ namespace CDP4JsonSerializer public class ScaleValueDefinitionSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not ScaleValueDefinition scaleValueDefinition) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a ScaleValueDefinition", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ScaleValueDefinition since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleValueDefinition for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(scaleValueDefinition.Iid); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(scaleValueDefinition.Name); writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - + writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); writer.WritePropertyName("shortName"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(scaleValueDefinition.Value); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleValueDefinition for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForValue.Contains(requestedVersion)) + foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("value"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the ScaleValueDefinition"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not ScaleValueDefinition scaleValueDefinition) - { - throw new ArgumentException("The thing shall be a ScaleValueDefinition", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ScaleValueDefinition since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(excludedDomainItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -476,8 +165,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(scaleValueDefinition.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(scaleValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(scaleValueDefinition.Name); writer.WritePropertyName("revisionNumber"u8); @@ -487,8 +179,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("value"u8); writer.WriteStringValue(scaleValueDefinition.Value); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleValueDefinition for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +189,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -507,6 +200,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -515,6 +209,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -523,6 +218,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -531,6 +227,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(scaleValueDefinition.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -541,11 +238,24 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(scaleValueDefinition.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(scaleValueDefinition.ThingPreference); writer.WritePropertyName("value"u8); writer.WriteStringValue(scaleValueDefinition.Value); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ScaleValueDefinition for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(scaleValueDefinition.Actor.HasValue) + { + writer.WriteStringValue(scaleValueDefinition.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) @@ -554,6 +264,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -564,6 +275,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -572,6 +284,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -580,6 +293,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -588,6 +302,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(scaleValueDefinition.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -603,82 +318,304 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("value"u8); writer.WriteStringValue(scaleValueDefinition.Value); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ScaleValueDefinition for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(scaleValueDefinition.Actor.HasValue) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(scaleValueDefinition.Actor.Value); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("alias"u8); - foreach(var aliasItem in scaleValueDefinition.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(aliasItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(scaleValueDefinition.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var definitionItem in scaleValueDefinition.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in scaleValueDefinition.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in scaleValueDefinition.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in scaleValueDefinition.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(scaleValueDefinition.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(scaleValueDefinition.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("name"u8); - writer.WriteStringValue(scaleValueDefinition.Name); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(scaleValueDefinition.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(scaleValueDefinition.ShortName); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(scaleValueDefinition.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "value": + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("value"u8); - writer.WriteStringValue(scaleValueDefinition.Value); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the ScaleValueDefinition"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs index 49fb9fa52..3d4aa0bf9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SectionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,218 @@ namespace CDP4JsonSerializer /// public class SectionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Section section) + { + throw new ArgumentException("The thing shall be a Section", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Section since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Section for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Section for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(section.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Section for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(section.Actor.HasValue) + { + writer.WriteStringValue(section.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(section.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(section.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(section.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(section.Owner); + writer.WriteStartArray("page"u8); + + foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(pageItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(section.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(section.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(section.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +269,7 @@ public class SectionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +277,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +295,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -111,14 +313,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +331,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -161,14 +349,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -186,14 +367,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -211,14 +385,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -236,14 +403,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -261,14 +421,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -286,14 +439,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -311,14 +457,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "page": - var allowedVersionsForPage = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPage.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["page"].Contains(requestedVersion)) { return; } @@ -336,14 +475,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,14 +493,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +511,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,204 +534,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Section section) - { - throw new ArgumentException("The thing shall be a Section", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Section since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(section.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(section.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(section.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(section.Owner); - writer.WriteStartArray("page"u8); - - foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(pageItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(section.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(section.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(section.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(section.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(section.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(section.Owner); - writer.WriteStartArray("page"u8); - - foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(pageItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(section.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(section.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(section.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Section for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(section.Actor.HasValue) - { - writer.WriteStringValue(section.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in section.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(section.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(section.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in section.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in section.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(section.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(section.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(section.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(section.Owner); - writer.WriteStartArray("page"u8); - - foreach(var pageItem in section.Page.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(pageItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(section.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(section.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(section.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "page", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs index c5318bfc6..2ced7f763 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SharedStyleSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,597 +51,195 @@ namespace CDP4JsonSerializer public class SharedStyleSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not SharedStyle sharedStyle) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a SharedStyle", nameof(thing)); + } - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SharedStyle since Version is below 1.1.0"); + return; + } - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SharedStyle for Version 1.1.0"); writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(sharedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in sharedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "fillcolor": - var allowedVersionsForFillColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFillColor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("fillColor"u8); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "fillopacity": - var allowedVersionsForFillOpacity = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForFillOpacity.Contains(requestedVersion)) + foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("fillOpacity"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((float)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "fontbold": - var allowedVersionsForFontBold = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontBold.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fillColor"u8); - writer.WritePropertyName("fontBold"u8); - - if(value != null) + if(sharedStyle.FillColor.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(sharedStyle.FillColor.Value); } else { writer.WriteNullValue(); } - break; - case "fontcolor": - var allowedVersionsForFontColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontColor.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fillOpacity"u8); - writer.WritePropertyName("fontColor"u8); - - if(value != null) + if(sharedStyle.FillOpacity.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteNumberValue(sharedStyle.FillOpacity.Value); } else { writer.WriteNullValue(); } - break; - case "fontitalic": - var allowedVersionsForFontItalic = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontItalic.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontBold"u8); - writer.WritePropertyName("fontItalic"u8); - - if(value != null) + if(sharedStyle.FontBold.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteBooleanValue(sharedStyle.FontBold.Value); } else { writer.WriteNullValue(); } - break; - case "fontname": - var allowedVersionsForFontName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontName.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontColor"u8); - writer.WritePropertyName("fontName"u8); - - if(value != null) + if(sharedStyle.FontColor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(sharedStyle.FontColor.Value); } else { writer.WriteNullValue(); } - break; - case "fontsize": - var allowedVersionsForFontSize = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontSize.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontItalic"u8); - writer.WritePropertyName("fontSize"u8); - - if(value != null) + if(sharedStyle.FontItalic.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteBooleanValue(sharedStyle.FontItalic.Value); } else { writer.WriteNullValue(); } - break; - case "fontstrokethrough": - var allowedVersionsForFontStrokeThrough = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontStrokeThrough.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontName"u8); + writer.WriteStringValue(sharedStyle.FontName); + writer.WritePropertyName("fontSize"u8); - writer.WritePropertyName("fontStrokeThrough"u8); - - if(value != null) + if(sharedStyle.FontSize.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteNumberValue(sharedStyle.FontSize.Value); } else { writer.WriteNullValue(); } - break; - case "fontunderline": - var allowedVersionsForFontUnderline = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForFontUnderline.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontStrokeThrough"u8); - writer.WritePropertyName("fontUnderline"u8); - - if(value != null) + if(sharedStyle.FontStrokeThrough.HasValue) { - writer.WriteBooleanValue((bool)value); + writer.WriteBooleanValue(sharedStyle.FontStrokeThrough.Value); } else { writer.WriteNullValue(); } - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("fontUnderline"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(sharedStyle.FontUnderline.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sharedStyle.Iid); writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(sharedStyle.Name); writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "strokecolor": - var allowedVersionsForStrokeColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeColor.Contains(requestedVersion)) - { - return; - } - + writer.WriteNumberValue(sharedStyle.RevisionNumber); writer.WritePropertyName("strokeColor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "strokeopacity": - var allowedVersionsForStrokeOpacity = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeOpacity.Contains(requestedVersion)) - { - return; - } - writer.WritePropertyName("strokeOpacity"u8); - - if(value != null) + if(sharedStyle.StrokeColor.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteStringValue(sharedStyle.StrokeColor.Value); } else { writer.WriteNullValue(); } - break; - case "strokewidth": - var allowedVersionsForStrokeWidth = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStrokeWidth.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("strokeOpacity"u8); - writer.WritePropertyName("strokeWidth"u8); - - if(value != null) + if(sharedStyle.StrokeOpacity.HasValue) { - writer.WriteNumberValue((float)value); + writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); } else { writer.WriteNullValue(); } - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("strokeWidth"u8); - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + if(sharedStyle.StrokeWidth.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); } else { writer.WriteNullValue(); } - break; - case "usedcolor": - var allowedVersionsForUsedColor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUsedColor.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("usedColor"u8); - if(value is IEnumerable objectListUsedColor) + foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) { - foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(usedColorItem); - } + writer.WriteStringValue(usedColorItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SharedStyle"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SharedStyle sharedStyle) - { - throw new ArgumentException("The thing shall be a SharedStyle", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SharedStyle since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SharedStyle for Version 1.2.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(sharedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -651,6 +250,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -659,6 +259,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); if(sharedStyle.FillColor.HasValue) @@ -790,6 +391,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNullValue(); } + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sharedStyle.ThingPreference); writer.WriteStartArray("usedColor"u8); foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) @@ -798,9 +401,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SharedStyle for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(sharedStyle.Actor.HasValue) + { + writer.WriteStringValue(sharedStyle.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(sharedStyle.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -811,6 +426,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -819,6 +435,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("fillColor"u8); if(sharedStyle.FillColor.HasValue) @@ -902,244 +519,516 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM if(sharedStyle.FontUnderline.HasValue) { - writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(sharedStyle.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(sharedStyle.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(sharedStyle.RevisionNumber); + writer.WritePropertyName("strokeColor"u8); + + if(sharedStyle.StrokeColor.HasValue) + { + writer.WriteStringValue(sharedStyle.StrokeColor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeOpacity"u8); + + if(sharedStyle.StrokeOpacity.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("strokeWidth"u8); + + if(sharedStyle.StrokeWidth.HasValue) + { + writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(sharedStyle.ThingPreference); + writer.WriteStartArray("usedColor"u8); + + foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "fillcolor": + if(!AllowedVersionsPerProperty["fillColor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("fillColor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(sharedStyle.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(sharedStyle.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(sharedStyle.RevisionNumber); - writer.WritePropertyName("strokeColor"u8); + break; + case "fillopacity": + if(!AllowedVersionsPerProperty["fillOpacity"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeColor.HasValue) + writer.WritePropertyName("fillOpacity"u8); + + if(value != null) { - writer.WriteStringValue(sharedStyle.StrokeColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeOpacity"u8); + break; + case "fontbold": + if(!AllowedVersionsPerProperty["fontBold"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeOpacity.HasValue) + writer.WritePropertyName("fontBold"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeWidth"u8); + break; + case "fontcolor": + if(!AllowedVersionsPerProperty["fontColor"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeWidth.HasValue) + writer.WritePropertyName("fontColor"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(sharedStyle.ThingPreference); - writer.WriteStartArray("usedColor"u8); - - foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + break; + case "fontitalic": + if(!AllowedVersionsPerProperty["fontItalic"].Contains(requestedVersion)) { - writer.WriteStringValue(usedColorItem); + return; } - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SharedStyle for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(sharedStyle.Actor.HasValue) + writer.WritePropertyName("fontItalic"u8); + + if(value != null) { - writer.WriteStringValue(sharedStyle.Actor.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(sharedStyle.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in sharedStyle.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "fontname": + if(!AllowedVersionsPerProperty["fontName"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in sharedStyle.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("fontName"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("fillColor"u8); + break; + case "fontsize": + if(!AllowedVersionsPerProperty["fontSize"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FillColor.HasValue) + writer.WritePropertyName("fontSize"u8); + + if(value != null) { - writer.WriteStringValue(sharedStyle.FillColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fillOpacity"u8); + break; + case "fontstrokethrough": + if(!AllowedVersionsPerProperty["fontStrokeThrough"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FillOpacity.HasValue) + writer.WritePropertyName("fontStrokeThrough"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.FillOpacity.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontBold"u8); + break; + case "fontunderline": + if(!AllowedVersionsPerProperty["fontUnderline"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontBold.HasValue) + writer.WritePropertyName("fontUnderline"u8); + + if(value != null) { - writer.WriteBooleanValue(sharedStyle.FontBold.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontColor"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontColor.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(sharedStyle.FontColor.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontItalic"u8); + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontItalic.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteBooleanValue(sharedStyle.FontItalic.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontName"u8); - writer.WriteStringValue(sharedStyle.FontName); - writer.WritePropertyName("fontSize"u8); + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontSize.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.FontSize.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontStrokeThrough"u8); + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontStrokeThrough.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteBooleanValue(sharedStyle.FontStrokeThrough.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("fontUnderline"u8); + break; + case "strokecolor": + if(!AllowedVersionsPerProperty["strokeColor"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.FontUnderline.HasValue) + writer.WritePropertyName("strokeColor"u8); + + if(value != null) { - writer.WriteBooleanValue(sharedStyle.FontUnderline.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(sharedStyle.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(sharedStyle.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(sharedStyle.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(sharedStyle.RevisionNumber); - writer.WritePropertyName("strokeColor"u8); + break; + case "strokeopacity": + if(!AllowedVersionsPerProperty["strokeOpacity"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeColor.HasValue) + writer.WritePropertyName("strokeOpacity"u8); + + if(value != null) { - writer.WriteStringValue(sharedStyle.StrokeColor.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeOpacity"u8); + break; + case "strokewidth": + if(!AllowedVersionsPerProperty["strokeWidth"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeOpacity.HasValue) + writer.WritePropertyName("strokeWidth"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.StrokeOpacity.Value); + writer.WriteNumberValue((float)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("strokeWidth"u8); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } - if(sharedStyle.StrokeWidth.HasValue) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteNumberValue(sharedStyle.StrokeWidth.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(sharedStyle.ThingPreference); + break; + case "usedcolor": + if(!AllowedVersionsPerProperty["usedColor"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("usedColor"u8); - foreach(var usedColorItem in sharedStyle.UsedColor.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUsedColor) { - writer.WriteStringValue(usedColorItem); + foreach(var usedColorItem in objectListUsedColor.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(usedColorItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SharedStyle"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fillColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fillOpacity", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontBold", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontItalic", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontSize", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontStrokeThrough", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fontUnderline", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeOpacity", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "strokeWidth", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "usedColor", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs index f8aae430a..4abe7173d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleParameterValueSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,205 @@ namespace CDP4JsonSerializer /// public class SimpleParameterValueSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not SimpleParameterValue simpleParameterValue) + { + throw new ArgumentException("The thing shall be a SimpleParameterValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleParameterValue since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleParameterValue for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleParameterValue for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleParameterValue for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleParameterValue.ThingPreference); + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleParameterValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(simpleParameterValue.Actor.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleParameterValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("parameterType"u8); + writer.WriteStringValue(simpleParameterValue.ParameterType); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleParameterValue.RevisionNumber); + writer.WritePropertyName("scale"u8); + + if(simpleParameterValue.Scale.HasValue) + { + writer.WriteStringValue(simpleParameterValue.Scale.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleParameterValue.ThingPreference); + writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +256,7 @@ public class SimpleParameterValueSerializer : BaseThingSerializer, IThingSeriali /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +264,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +282,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +300,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +318,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +336,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +354,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +372,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { return; } @@ -239,15 +390,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -265,15 +408,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { return; } @@ -291,13 +426,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -315,15 +444,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -336,197 +457,22 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not SimpleParameterValue simpleParameterValue) - { - throw new ArgumentException("The thing shall be a SimpleParameterValue", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SimpleParameterValue since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleParameterValue.Iid); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(simpleParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(simpleParameterValue.Scale.HasValue) - { - writer.WriteStringValue(simpleParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(simpleParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(simpleParameterValue.Scale.HasValue) - { - writer.WriteStringValue(simpleParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(simpleParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(simpleParameterValue.Scale.HasValue) - { - writer.WriteStringValue(simpleParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(simpleParameterValue.ThingPreference); - writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleParameterValue for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(simpleParameterValue.Actor.HasValue) - { - writer.WriteStringValue(simpleParameterValue.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleParameterValue.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleParameterValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleParameterValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleParameterValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleParameterValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("parameterType"u8); - writer.WriteStringValue(simpleParameterValue.ParameterType); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleParameterValue.RevisionNumber); - writer.WritePropertyName("scale"u8); - - if(simpleParameterValue.Scale.HasValue) - { - writer.WriteStringValue(simpleParameterValue.Scale.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(simpleParameterValue.ThingPreference); - writer.WriteString("value"u8, simpleParameterValue.Value.ToJsonString()); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs index d1564944c..0381206b4 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleQuantityKindSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,401 @@ namespace CDP4JsonSerializer public class SimpleQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not SimpleQuantityKind simpleQuantityKind) + { + throw new ArgumentException("The thing shall be a SimpleQuantityKind", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleQuantityKind since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(value is IEnumerable objectListAlias) + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(possibleScaleItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "defaultscale": - var allowedVersionsForDefaultScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("defaultScale"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(possibleScaleItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListDefinition) + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleScaleItem); } - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleQuantityKind.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(simpleQuantityKind.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(simpleQuantityKind.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(simpleQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(simpleQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(possibleScaleItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(simpleQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleQuantityKind.ThingPreference); break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForName.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +453,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "possiblescale": - var allowedVersionsForPossibleScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("possibleScale"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListPossibleScale) + if(value is IEnumerable objectListAlias) { - foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(possibleScaleItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "quantitydimensionsymbol": - var allowedVersionsForQuantityDimensionSymbol = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,25 +507,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "defaultscale": + if(!AllowedVersionsPerProperty["defaultScale"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("defaultScale"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -472,51 +525,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue((string)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); break; - case "symbol": - var allowedVersionsForSymbol = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -524,23 +615,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -548,355 +633,180 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleQuantityKind"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SimpleQuantityKind simpleQuantityKind) - { - throw new ArgumentException("The thing shall be a SimpleQuantityKind", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SimpleQuantityKind since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(simpleQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(simpleQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(possibleScaleItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(simpleQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(simpleQuantityKind.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(simpleQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "possiblescale": + if(!AllowedVersionsPerProperty["possibleScale"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(simpleQuantityKind.Name); writer.WriteStartArray("possibleScale"u8); - foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPossibleScale) { - writer.WriteStringValue(possibleScaleItem); + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(simpleQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(simpleQuantityKind.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + case "quantitydimensionsymbol": + if(!AllowedVersionsPerProperty["quantityDimensionSymbol"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(simpleQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(simpleQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(simpleQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(simpleQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(simpleQuantityKind.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleQuantityKind for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(simpleQuantityKind.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(simpleQuantityKind.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in simpleQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in simpleQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(simpleQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in simpleQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in simpleQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in simpleQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in simpleQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(simpleQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(simpleQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in simpleQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(possibleScaleItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(simpleQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(simpleQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(simpleQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(simpleQuantityKind.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleQuantityKind"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "quantityDimensionSymbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs index 37ce4c2b7..95afddc3b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SimpleUnitSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,424 +51,112 @@ namespace CDP4JsonSerializer public class SimpleUnitSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not SimpleUnit simpleUnit) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a SimpleUnit", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SimpleUnit since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleUnit for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(simpleUnit.Iid); writer.WritePropertyName("isDeprecated"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WriteBooleanValue(simpleUnit.IsDeprecated); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(simpleUnit.Name); writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WriteNumberValue(simpleUnit.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(simpleUnit.ShortName); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleUnit for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(simpleUnit.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleUnit"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SimpleUnit simpleUnit) - { - throw new ArgumentException("The thing shall be a SimpleUnit", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SimpleUnit since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(excludedDomainItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -476,10 +165,13 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(simpleUnit.Iid); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(simpleUnit.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(simpleUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(simpleUnit.Name); writer.WritePropertyName("revisionNumber"u8); @@ -487,8 +179,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("shortName"u8); writer.WriteStringValue(simpleUnit.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleUnit for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +189,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(simpleUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -507,6 +200,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -515,6 +209,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -523,6 +218,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -531,6 +227,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(simpleUnit.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -543,9 +240,22 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(simpleUnit.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(simpleUnit.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(simpleUnit.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SimpleUnit for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(simpleUnit.Actor.HasValue) + { + writer.WriteStringValue(simpleUnit.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) @@ -554,6 +264,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(simpleUnit.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -564,6 +275,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -572,6 +284,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -580,6 +293,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -588,6 +302,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(simpleUnit.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -603,82 +318,304 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("thingPreference"u8); writer.WriteStringValue(simpleUnit.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SimpleUnit for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(simpleUnit.Actor.HasValue) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(simpleUnit.Actor.Value); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("alias"u8); - foreach(var aliasItem in simpleUnit.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(aliasItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(simpleUnit.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var definitionItem in simpleUnit.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in simpleUnit.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in simpleUnit.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in simpleUnit.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(simpleUnit.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(simpleUnit.IsDeprecated); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(simpleUnit.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("name"u8); - writer.WriteStringValue(simpleUnit.Name); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(simpleUnit.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(simpleUnit.ShortName); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(simpleUnit.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SimpleUnit"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs index 91fb72ddb..727c19091 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataAnnotationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,224 @@ namespace CDP4JsonSerializer /// public class SiteDirectoryDataAnnotationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not SiteDirectoryDataAnnotation siteDirectoryDataAnnotation) + { + throw new ArgumentException("The thing shall be a SiteDirectoryDataAnnotation", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataAnnotation since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataAnnotation for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataAnnotation for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataAnnotation for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryDataAnnotation.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryDataAnnotation.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("discussion"u8); + + foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(discussionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("primaryAnnotatedThing"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); + writer.WriteStartArray("relatedThing"u8); + + foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(relatedThingItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +275,7 @@ public class SiteDirectoryDataAnnotationSerializer : BaseThingSerializer, IThing /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "discussion": - var allowedVersionsForDiscussion = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDiscussion.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["discussion"].Contains(requestedVersion)) { return; } @@ -211,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -236,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -261,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -311,14 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -336,14 +481,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "primaryannotatedthing": - var allowedVersionsForPrimaryAnnotatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPrimaryAnnotatedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["primaryAnnotatedThing"].Contains(requestedVersion)) { return; } @@ -361,14 +499,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "relatedthing": - var allowedVersionsForRelatedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRelatedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["relatedThing"].Contains(requestedVersion)) { return; } @@ -386,14 +517,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -411,13 +535,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -440,210 +558,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not SiteDirectoryDataAnnotation siteDirectoryDataAnnotation) - { - throw new ArgumentException("The thing shall be a SiteDirectoryDataAnnotation", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataAnnotation since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataAnnotation for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(siteDirectoryDataAnnotation.Actor.HasValue) - { - writer.WriteStringValue(siteDirectoryDataAnnotation.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("discussion"u8); - - foreach(var discussionItem in siteDirectoryDataAnnotation.Discussion.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(discussionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataAnnotation.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataAnnotation.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("primaryAnnotatedThing"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.PrimaryAnnotatedThing); - writer.WriteStartArray("relatedThing"u8); - - foreach(var relatedThingItem in siteDirectoryDataAnnotation.RelatedThing.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(relatedThingItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataAnnotation.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryDataAnnotation.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "discussion", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "primaryAnnotatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "relatedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs index b04f9b5d1..227f64e26 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryDataDiscussionItemSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,197 @@ namespace CDP4JsonSerializer /// public class SiteDirectoryDataDiscussionItemSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not SiteDirectoryDataDiscussionItem siteDirectoryDataDiscussionItem) + { + throw new ArgumentException("The thing shall be a SiteDirectoryDataDiscussionItem", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataDiscussionItem since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataDiscussionItem for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataDiscussionItem for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryDataDiscussionItem for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryDataDiscussionItem.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("replyTo"u8); + + if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) + { + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +248,7 @@ public class SiteDirectoryDataDiscussionItemSerializer : BaseThingSerializer, IT /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +256,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +274,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +292,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +310,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +328,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +346,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +364,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +382,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -261,14 +400,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -286,14 +418,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +436,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "replyto": - var allowedVersionsForReplyTo = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReplyTo.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["replyTo"].Contains(requestedVersion)) { return; } @@ -336,14 +454,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,13 +472,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -390,189 +495,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not SiteDirectoryDataDiscussionItem siteDirectoryDataDiscussionItem) - { - throw new ArgumentException("The thing shall be a SiteDirectoryDataDiscussionItem", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryDataDiscussionItem since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryDataDiscussionItem for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(siteDirectoryDataDiscussionItem.Actor.HasValue) - { - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryDataDiscussionItem.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryDataDiscussionItem.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("replyTo"u8); - - if(siteDirectoryDataDiscussionItem.ReplyTo.HasValue) - { - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ReplyTo.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryDataDiscussionItem.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryDataDiscussionItem.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "replyTo", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs index 0b02b53b6..64dd01191 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectorySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,691 +51,499 @@ namespace CDP4JsonSerializer public class SiteDirectorySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not SiteDirectory siteDirectory) + { + throw new ArgumentException("The thing shall be a SiteDirectory", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectory since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); - writer.WritePropertyName("actor"u8); - - if(value != null) + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectory for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); } else { writer.WriteNullValue(); } - break; - case "annotation": - var allowedVersionsForAnnotation = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("defaultPersonRole"u8); - if(!allowedVersionsForAnnotation.Contains(requestedVersion)) + if(siteDirectory.DefaultPersonRole.HasValue) { - return; + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("annotation"u8); + writer.WriteStartArray("domain"u8); - if(value is IEnumerable objectListAnnotation) + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) { - foreach(var annotationItem in objectListAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(annotationItem); - } + writer.WriteStringValue(domainItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("domainGroup"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainGroupItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); + + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(logEntryItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("model"u8); + + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(modelItem); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(naturalLanguageItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("organization"u8); + + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(organizationItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("participantRole"u8); + + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(participantRoleItem); } - break; - case "defaultparticipantrole": - var allowedVersionsForDefaultParticipantRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("person"u8); - if(!allowedVersionsForDefaultParticipantRole.Contains(requestedVersion)) + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(personItem); } - writer.WritePropertyName("defaultParticipantRole"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("personRole"u8); + + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(personRoleItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(siteReferenceDataLibraryItem); } + writer.WriteEndArray(); + break; - case "defaultpersonrole": - var allowedVersionsForDefaultPersonRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectory for Version 1.1.0"); + writer.WriteStartArray("annotation"u8); - if(!allowedVersionsForDefaultPersonRole.Contains(requestedVersion)) + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(annotationItem); } - writer.WritePropertyName("defaultPersonRole"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); } else { writer.WriteNullValue(); } - break; - case "domain": - var allowedVersionsForDomain = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("defaultPersonRole"u8); - if(!allowedVersionsForDomain.Contains(requestedVersion)) + if(siteDirectory.DefaultPersonRole.HasValue) { - return; + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + } + else + { + writer.WriteNullValue(); } writer.WriteStartArray("domain"u8); - if(value is IEnumerable objectListDomain) + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) { - foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainItem); - } + writer.WriteStringValue(domainItem); } - + writer.WriteEndArray(); - break; - case "domaingroup": - var allowedVersionsForDomainGroup = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("domainGroup"u8); - if(!allowedVersionsForDomainGroup.Contains(requestedVersion)) + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainGroupItem); } - writer.WriteStartArray("domainGroup"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListDomainGroup) + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var domainGroupItem in objectListDomainGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(domainGroupItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(logEntryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("model"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(modelItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(naturalLanguageItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("organization"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(organizationItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "lastmodifiedon": - var allowedVersionsForLastModifiedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("participantRole"u8); - if(!allowedVersionsForLastModifiedOn.Contains(requestedVersion)) + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(participantRoleItem); } - writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "logentry": - var allowedVersionsForLogEntry = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("person"u8); - if(!allowedVersionsForLogEntry.Contains(requestedVersion)) + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(personItem); } - writer.WriteStartArray("logEntry"u8); - - if(value is IEnumerable objectListLogEntry) - { - foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(logEntryItem); - } - } - writer.WriteEndArray(); - break; - case "model": - var allowedVersionsForModel = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("personRole"u8); - if(!allowedVersionsForModel.Contains(requestedVersion)) + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(personRoleItem); } - writer.WriteStartArray("model"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); - if(value is IEnumerable objectListModel) + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) { - foreach(var modelItem in objectListModel.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(modelItem); - } + writer.WriteStringValue(siteReferenceDataLibraryItem); } - + writer.WriteEndArray(); + break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectory for Version 1.2.0"); + writer.WriteStartArray("annotation"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(annotationItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectory.ClassKind.ToString()); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("defaultParticipantRole"u8); + + if(siteDirectory.DefaultParticipantRole.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); } else { writer.WriteNullValue(); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } + writer.WritePropertyName("defaultPersonRole"u8); - writer.WritePropertyName("name"u8); - - if(value != null) + if(siteDirectory.DefaultPersonRole.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); } else { writer.WriteNullValue(); } - break; - case "naturallanguage": - var allowedVersionsForNaturalLanguage = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("domain"u8); - if(!allowedVersionsForNaturalLanguage.Contains(requestedVersion)) + foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(domainItem); } - writer.WriteStartArray("naturalLanguage"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("domainGroup"u8); - if(value is IEnumerable objectListNaturalLanguage) + foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) { - foreach(var naturalLanguageItem in objectListNaturalLanguage.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(naturalLanguageItem); - } + writer.WriteStringValue(domainGroupItem); } - + writer.WriteEndArray(); - break; - case "organization": - var allowedVersionsForOrganization = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForOrganization.Contains(requestedVersion)) + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("organization"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListOrganization) + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var organizationItem in objectListOrganization.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(organizationItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "participantrole": - var allowedVersionsForParticipantRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectory.Iid); + writer.WritePropertyName("lastModifiedOn"u8); + writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("logEntry"u8); - if(!allowedVersionsForParticipantRole.Contains(requestedVersion)) + foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(logEntryItem); } - writer.WriteStartArray("participantRole"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("model"u8); - if(value is IEnumerable objectListParticipantRole) + foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) { - foreach(var participantRoleItem in objectListParticipantRole.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(participantRoleItem); - } + writer.WriteStringValue(modelItem); } - + writer.WriteEndArray(); - break; - case "person": - var allowedVersionsForPerson = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteDirectory.Name); + writer.WriteStartArray("naturalLanguage"u8); - if(!allowedVersionsForPerson.Contains(requestedVersion)) + foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(naturalLanguageItem); } - writer.WriteStartArray("person"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("organization"u8); - if(value is IEnumerable objectListPerson) + foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) { - foreach(var personItem in objectListPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(personItem); - } + writer.WriteStringValue(organizationItem); } - + writer.WriteEndArray(); - break; - case "personrole": - var allowedVersionsForPersonRole = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("participantRole"u8); - if(!allowedVersionsForPersonRole.Contains(requestedVersion)) + foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(participantRoleItem); } - writer.WriteStartArray("personRole"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("person"u8); - if(value is IEnumerable objectListPersonRole) + foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) { - foreach(var personRoleItem in objectListPersonRole.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(personRoleItem); - } + writer.WriteStringValue(personItem); } - + writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("personRole"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(personRoleItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectory.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteDirectory.ShortName); + writer.WriteStartArray("siteReferenceDataLibrary"u8); + + foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(siteReferenceDataLibraryItem); } - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectory.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectory for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectory.Actor.HasValue) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(siteDirectory.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "sitereferencedatalibrary": - var allowedVersionsForSiteReferenceDataLibrary = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("annotation"u8); - if(!allowedVersionsForSiteReferenceDataLibrary.Contains(requestedVersion)) + foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(annotationItem); } - writer.WriteStartArray("siteReferenceDataLibrary"u8); - - if(value is IEnumerable objectListSiteReferenceDataLibrary) - { - foreach(var siteReferenceDataLibraryItem in objectListSiteReferenceDataLibrary.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(siteReferenceDataLibraryItem); - } - } - writer.WriteEndArray(); - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectory"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SiteDirectory siteDirectory) - { - throw new ArgumentException("The thing shall be a SiteDirectory", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectory since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.0.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(siteDirectory.ClassKind.ToString()); writer.WritePropertyName("createdOn"u8); @@ -769,6 +578,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("domainGroup"u8); foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) @@ -777,6 +587,25 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(siteDirectory.Iid); writer.WritePropertyName("lastModifiedOn"u8); @@ -789,6 +618,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("model"u8); foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) @@ -797,6 +627,9 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(siteDirectory.Name); writer.WriteStartArray("naturalLanguage"u8); @@ -807,6 +640,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("organization"u8); foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) @@ -815,6 +649,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("participantRole"u8); foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) @@ -823,6 +658,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("person"u8); foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) @@ -831,6 +667,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("personRole"u8); foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) @@ -839,6 +676,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(siteDirectory.RevisionNumber); writer.WritePropertyName("shortName"u8); @@ -851,463 +689,517 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectory.ThingPreference); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.1.0"); - writer.WriteStartArray("annotation"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(annotationItem); - } + writer.WriteEndObject(); + } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectory.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("defaultParticipantRole"u8); + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(siteDirectory.DefaultParticipantRole.HasValue) - { - writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); - } - else + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WritePropertyName("defaultPersonRole"u8); - - if(siteDirectory.DefaultPersonRole.HasValue) + writer.WritePropertyName("actor"u8); + + if(value != null) { - writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("domain"u8); - - foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + break; + case "annotation": + if(!AllowedVersionsPerProperty["annotation"].Contains(requestedVersion)) { - writer.WriteStringValue(domainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("domainGroup"u8); + writer.WriteStartArray("annotation"u8); - foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAnnotation) { - writer.WriteStringValue(domainGroupItem); + foreach(var annotationItem in objectListAnnotation.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(annotationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("classKind"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((ClassKind)value).ToString()); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectory.Iid); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); - - foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(logEntryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("model"u8); - - foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + break; + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { - writer.WriteStringValue(modelItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(siteDirectory.Name); - writer.WriteStartArray("naturalLanguage"u8); - - foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("createdOn"u8); + + if(value != null) { - writer.WriteStringValue(naturalLanguageItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("organization"u8); - - foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(organizationItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("participantRole"u8); - - foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + break; + case "defaultparticipantrole": + if(!AllowedVersionsPerProperty["defaultParticipantRole"].Contains(requestedVersion)) { - writer.WriteStringValue(participantRoleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("person"u8); - - foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("defaultParticipantRole"u8); + + if(value != null) { - writer.WriteStringValue(personItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("personRole"u8); - - foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(personRoleItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectory.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(siteDirectory.ShortName); - writer.WriteStartArray("siteReferenceDataLibrary"u8); - - foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(siteReferenceDataLibraryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.2.0"); - writer.WriteStartArray("annotation"u8); - - foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) + case "defaultpersonrole": + if(!AllowedVersionsPerProperty["defaultPersonRole"].Contains(requestedVersion)) { - writer.WriteStringValue(annotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectory.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("defaultParticipantRole"u8); - - if(siteDirectory.DefaultParticipantRole.HasValue) + writer.WritePropertyName("defaultPersonRole"u8); + + if(value != null) { - writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("defaultPersonRole"u8); - - if(siteDirectory.DefaultPersonRole.HasValue) - { - writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); - } - else + break; + case "domain": + if(!AllowedVersionsPerProperty["domain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } writer.WriteStartArray("domain"u8); - foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDomain) { - writer.WriteStringValue(domainItem); + foreach(var domainItem in objectListDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainItem); + } } - + writer.WriteEndArray(); + break; + case "domaingroup": + if(!AllowedVersionsPerProperty["domainGroup"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("domainGroup"u8); - foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDomainGroup) { - writer.WriteStringValue(domainGroupItem); + foreach(var domainGroupItem in objectListDomainGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(domainGroupItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectory.Iid); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); - - foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(logEntryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("model"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(modelItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(siteDirectory.Name); - writer.WriteStartArray("naturalLanguage"u8); - - foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(naturalLanguageItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("organization"u8); + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + break; + case "lastmodifiedon": + if(!AllowedVersionsPerProperty["lastModifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(organizationItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("participantRole"u8); + writer.WritePropertyName("lastModifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } - foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + break; + case "logentry": + if(!AllowedVersionsPerProperty["logEntry"].Contains(requestedVersion)) { - writer.WriteStringValue(participantRoleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("person"u8); + writer.WriteStartArray("logEntry"u8); - foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListLogEntry) { - writer.WriteStringValue(personItem); + foreach(var logEntryItem in objectListLogEntry.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("personRole"u8); - - foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + break; + case "model": + if(!AllowedVersionsPerProperty["model"].Contains(requestedVersion)) { - writer.WriteStringValue(personRoleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectory.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(siteDirectory.ShortName); - writer.WriteStartArray("siteReferenceDataLibrary"u8); + writer.WriteStartArray("model"u8); - foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListModel) { - writer.WriteStringValue(siteReferenceDataLibraryItem); + foreach(var modelItem in objectListModel.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(modelItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectory.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectory for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } - if(siteDirectory.Actor.HasValue) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(siteDirectory.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("annotation"u8); - - foreach(var annotationItem in siteDirectory.Annotation.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(annotationItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectory.ClassKind.ToString()); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteDirectory.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("defaultParticipantRole"u8); - - if(siteDirectory.DefaultParticipantRole.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(siteDirectory.DefaultParticipantRole.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("defaultPersonRole"u8); + break; + case "naturallanguage": + if(!AllowedVersionsPerProperty["naturalLanguage"].Contains(requestedVersion)) + { + return; + } - if(siteDirectory.DefaultPersonRole.HasValue) + writer.WriteStartArray("naturalLanguage"u8); + + if(value is IEnumerable objectListNaturalLanguage) { - writer.WriteStringValue(siteDirectory.DefaultPersonRole.Value); + foreach(var naturalLanguageItem in objectListNaturalLanguage.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(naturalLanguageItem); + } } - else + + writer.WriteEndArray(); + break; + case "organization": + if(!AllowedVersionsPerProperty["organization"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("domain"u8); + writer.WriteStartArray("organization"u8); - foreach(var domainItem in siteDirectory.Domain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListOrganization) { - writer.WriteStringValue(domainItem); + foreach(var organizationItem in objectListOrganization.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(organizationItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("domainGroup"u8); - - foreach(var domainGroupItem in siteDirectory.DomainGroup.OrderBy(x => x, this.GuidComparer)) + break; + case "participantrole": + if(!AllowedVersionsPerProperty["participantRole"].Contains(requestedVersion)) { - writer.WriteStringValue(domainGroupItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("participantRole"u8); - foreach(var excludedDomainItem in siteDirectory.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListParticipantRole) { - writer.WriteStringValue(excludedDomainItem); + foreach(var participantRoleItem in objectListParticipantRole.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(participantRoleItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectory.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "person": + if(!AllowedVersionsPerProperty["person"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectory.Iid); - writer.WritePropertyName("lastModifiedOn"u8); - writer.WriteStringValue(siteDirectory.LastModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("logEntry"u8); + writer.WriteStartArray("person"u8); - foreach(var logEntryItem in siteDirectory.LogEntry.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPerson) { - writer.WriteStringValue(logEntryItem); + foreach(var personItem in objectListPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("model"u8); - - foreach(var modelItem in siteDirectory.Model.OrderBy(x => x, this.GuidComparer)) + break; + case "personrole": + if(!AllowedVersionsPerProperty["personRole"].Contains(requestedVersion)) { - writer.WriteStringValue(modelItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectory.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(siteDirectory.Name); - writer.WriteStartArray("naturalLanguage"u8); + writer.WriteStartArray("personRole"u8); - foreach(var naturalLanguageItem in siteDirectory.NaturalLanguage.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPersonRole) { - writer.WriteStringValue(naturalLanguageItem); + foreach(var personRoleItem in objectListPersonRole.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(personRoleItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("organization"u8); - - foreach(var organizationItem in siteDirectory.Organization.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(organizationItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("participantRole"u8); - - foreach(var participantRoleItem in siteDirectory.ParticipantRole.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(participantRoleItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("person"u8); - - foreach(var personItem in siteDirectory.Person.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(personItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("personRole"u8); + writer.WritePropertyName("shortName"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var personRoleItem in siteDirectory.PersonRole.OrderBy(x => x, this.GuidComparer)) + break; + case "sitereferencedatalibrary": + if(!AllowedVersionsPerProperty["siteReferenceDataLibrary"].Contains(requestedVersion)) { - writer.WriteStringValue(personRoleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectory.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(siteDirectory.ShortName); writer.WriteStartArray("siteReferenceDataLibrary"u8); - foreach(var siteReferenceDataLibraryItem in siteDirectory.SiteReferenceDataLibrary.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSiteReferenceDataLibrary) { - writer.WriteStringValue(siteReferenceDataLibraryItem); + foreach(var siteReferenceDataLibraryItem in objectListSiteReferenceDataLibrary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(siteReferenceDataLibraryItem); + } } - + writer.WriteEndArray(); + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectory.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteDirectory"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "annotation", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultParticipantRole", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultPersonRole", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "domain", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "domainGroup", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "lastModifiedOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "logEntry", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "model", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "naturalLanguage", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "organization", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "participantRole", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "person", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "personRole", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "siteReferenceDataLibrary", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs index 22b0c2310..4600c357d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteDirectoryThingReferenceSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,152 @@ namespace CDP4JsonSerializer /// public class SiteDirectoryThingReferenceSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not SiteDirectoryThingReference siteDirectoryThingReference) + { + throw new ArgumentException("The thing shall be a SiteDirectoryThingReference", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryThingReference since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryThingReference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryThingReference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteDirectoryThingReference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteDirectoryThingReference.Actor.HasValue) + { + writer.WriteStringValue(siteDirectoryThingReference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteDirectoryThingReference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("referencedRevisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); + writer.WritePropertyName("referencedThing"u8); + writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +203,7 @@ public class SiteDirectoryThingReferenceSerializer : BaseThingSerializer, IThing /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +211,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +229,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -111,14 +247,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -136,14 +265,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -161,14 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -186,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -211,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencedrevisionnumber": - var allowedVersionsForReferencedRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencedRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencedRevisionNumber"].Contains(requestedVersion)) { return; } @@ -236,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "referencedthing": - var allowedVersionsForReferencedThing = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForReferencedThing.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["referencedThing"].Contains(requestedVersion)) { return; } @@ -261,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -286,13 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -315,144 +396,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not SiteDirectoryThingReference siteDirectoryThingReference) - { - throw new ArgumentException("The thing shall be a SiteDirectoryThingReference", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteDirectoryThingReference since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteDirectoryThingReference for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(siteDirectoryThingReference.Actor.HasValue) - { - writer.WriteStringValue(siteDirectoryThingReference.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteDirectoryThingReference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteDirectoryThingReference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteDirectoryThingReference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteDirectoryThingReference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteDirectoryThingReference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("referencedRevisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.ReferencedRevisionNumber); - writer.WritePropertyName("referencedThing"u8); - writer.WriteStringValue(siteDirectoryThingReference.ReferencedThing); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteDirectoryThingReference.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteDirectoryThingReference.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedRevisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "referencedThing", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs index 89790245c..407871d73 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteLogEntrySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,288 +51,371 @@ namespace CDP4JsonSerializer public class SiteLogEntrySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not SiteLogEntry siteLogEntry) + { + throw new ArgumentException("The thing shall be a SiteLogEntry", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List + Logger.Log(LogLevel.Info, "Skipping serialization of SiteLogEntry since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SiteLogEntry for Version 1.0.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) { - "1.3.0", - }; + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(siteLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "affecteddomainiid": - var allowedVersionsForAffectedDomainIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForAffectedDomainIid.Contains(requestedVersion)) + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("affectedDomainIid"u8); - - if(value is IEnumerable objectListAffectedDomainIid) - { - foreach(var affectedDomainIidItem in objectListAffectedDomainIid) - { - writer.WriteStringValue((Guid)affectedDomainIidItem); - } - } - writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); break; - case "affecteditemiid": - var allowedVersionsForAffectedItemIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteLogEntry for Version 1.1.0"); + writer.WriteStartArray("affectedDomainIid"u8); - if(!allowedVersionsForAffectedItemIid.Contains(requestedVersion)) + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) { - return; + writer.WriteStringValue(affectedDomainIidItem); } - writer.WriteStartArray("affectedItemIid"u8); - - if(value is IEnumerable objectListAffectedItemIid) - { - foreach(var affectedItemIidItem in objectListAffectedItemIid) - { - writer.WriteStringValue((Guid)affectedItemIidItem); - } - } - writer.WriteEndArray(); - break; - case "author": - var allowedVersionsForAuthor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("author"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(siteLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListCategory) + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(excludedDomainItem); } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); break; - case "classkind": - var allowedVersionsForClassKind = new List + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteLogEntry for Version 1.2.0"); + writer.WriteStartArray("affectedDomainIid"u8); + + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(affectedDomainIidItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) { - return; + writer.WriteStringValue(affectedItemIidItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(siteLogEntry.Author.Value); } else { writer.WriteNullValue(); } - break; - case "content": - var allowedVersionsForContent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForContent.Contains(requestedVersion)) + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("content"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(excludedDomainItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(logEntryChangelogItemItem); } - writer.WritePropertyName("createdOn"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteLogEntry.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteLogEntry for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteLogEntry.Actor.HasValue) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(siteLogEntry.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("affectedDomainIid"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) { - return; + writer.WriteStringValue(affectedDomainIidItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("affectedItemIid"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(affectedItemIidItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List + + writer.WritePropertyName("author"u8); + + if(siteLogEntry.Author.HasValue) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(siteLogEntry.Author.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(siteLogEntry.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } + + writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteLogEntry.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(siteLogEntry.LanguageCode); + writer.WritePropertyName("level"u8); + writer.WriteStringValue(siteLogEntry.Level.ToString()); + writer.WriteStartArray("logEntryChangelogItem"u8); + + foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } + writer.WriteEndArray(); + + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteLogEntry.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteLogEntry.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -343,51 +427,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + case "affecteddomainiid": + if(!AllowedVersionsPerProperty["affectedDomainIid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("languageCode"u8); - - if(value != null) + writer.WriteStartArray("affectedDomainIid"u8); + + if(value is IEnumerable objectListAffectedDomainIid) { - writer.WriteStringValue((string)value); + foreach(var affectedDomainIidItem in objectListAffectedDomainIid) + { + writer.WriteStringValue((Guid)affectedDomainIidItem); + } } - else + + writer.WriteEndArray(); + break; + case "affecteditemiid": + if(!AllowedVersionsPerProperty["affectedItemIid"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "level": - var allowedVersionsForLevel = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("affectedItemIid"u8); - if(!allowedVersionsForLevel.Contains(requestedVersion)) + if(value is IEnumerable objectListAffectedItemIid) + { + foreach(var affectedItemIidItem in objectListAffectedItemIid) + { + writer.WriteStringValue((Guid)affectedItemIidItem); + } + } + + writer.WriteEndArray(); + break; + case "author": + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("level"u8); + writer.WritePropertyName("author"u8); if(value != null) { - writer.WriteStringValue(((LogLevelKind)value).ToString()); + writer.WriteStringValue((Guid)value); } else { @@ -395,48 +481,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "logentrychangelogitem": - var allowedVersionsForLogEntryChangelogItem = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLogEntryChangelogItem.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("logEntryChangelogItem"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListLogEntryChangelogItem) + if(value is IEnumerable objectListCategory) { - foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(logEntryChangelogItemItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -444,25 +517,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "content": + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("content"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((string)value); } else { @@ -470,23 +535,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "createdon": + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("createdOn"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { @@ -494,335 +553,196 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteLogEntry"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SiteLogEntry siteLogEntry) - { - throw new ArgumentException("The thing shall be a SiteLogEntry", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteLogEntry since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.0.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedDomainIidItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(affectedItemIidItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(siteLogEntry.Author.HasValue) - { - writer.WriteStringValue(siteLogEntry.Author.Value); - } - else + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - writer.WriteStartArray("category"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(categoryItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(siteLogEntry.Level.ToString()); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteLogEntry.RevisionNumber); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.1.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(siteLogEntry.Author.HasValue) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(siteLogEntry.Author.Value); + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "languagecode": + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("languageCode"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(siteLogEntry.Level.ToString()); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteLogEntry.RevisionNumber); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.2.0"); - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + case "level": + if(!AllowedVersionsPerProperty["level"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(siteLogEntry.Author.HasValue) + writer.WritePropertyName("level"u8); + + if(value != null) { - writer.WriteStringValue(siteLogEntry.Author.Value); + writer.WriteStringValue(((LogLevelKind)value).ToString()); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "logentrychangelogitem": + if(!AllowedVersionsPerProperty["logEntryChangelogItem"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("logEntryChangelogItem"u8); - foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListLogEntryChangelogItem) { - writer.WriteStringValue(excludedPersonItem); + foreach(var logEntryChangelogItemItem in objectListLogEntryChangelogItem.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(logEntryChangelogItemItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(siteLogEntry.Level.ToString()); - writer.WriteStartArray("logEntryChangelogItem"u8); - - foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(logEntryChangelogItemItem); + return; } - writer.WriteEndArray(); writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteLogEntry.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteLogEntry.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteLogEntry for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(siteLogEntry.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(siteLogEntry.Actor.Value); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } else { writer.WriteNullValue(); } - writer.WriteStartArray("affectedDomainIid"u8); - - foreach(var affectedDomainIidItem in siteLogEntry.AffectedDomainIid) - { - writer.WriteStringValue(affectedDomainIidItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("affectedItemIid"u8); - - foreach(var affectedItemIidItem in siteLogEntry.AffectedItemIid) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(affectedItemIidItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("author"u8); - - if(siteLogEntry.Author.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(siteLogEntry.Author.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in siteLogEntry.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteLogEntry.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(siteLogEntry.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(siteLogEntry.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteLogEntry.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteLogEntry.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteLogEntry.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(siteLogEntry.LanguageCode); - writer.WritePropertyName("level"u8); - writer.WriteStringValue(siteLogEntry.Level.ToString()); - writer.WriteStartArray("logEntryChangelogItem"u8); - - foreach(var logEntryChangelogItemItem in siteLogEntry.LogEntryChangelogItem.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(logEntryChangelogItemItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteLogEntry.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteLogEntry.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteLogEntry.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteLogEntry"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "affectedDomainIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "affectedItemIid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "author", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "level", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "logEntryChangelogItem", new []{ "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs index 138ecdcfc..d4efc9722 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SiteReferenceDataLibrarySerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,822 +51,481 @@ namespace CDP4JsonSerializer public class SiteReferenceDataLibrarySerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not SiteReferenceDataLibrary siteReferenceDataLibrary) + { + throw new ArgumentException("The thing shall be a SiteReferenceDataLibrary", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of SiteReferenceDataLibrary since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SiteReferenceDataLibrary for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("baseQuantityKind"u8); + + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteOrderedItem(baseQuantityKindItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("baseUnit"u8); + + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(baseUnitItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(constantItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definedCategory"u8); - if(value is IEnumerable objectListAlias) + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(definedCategoryItem); } - + writer.WriteEndArray(); - break; - case "basequantitykind": - var allowedVersionsForBaseQuantityKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForBaseQuantityKind.Contains(requestedVersion)) + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("baseQuantityKind"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("fileType"u8); - if(value is IEnumerable objectListBaseQuantityKind) + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) { - foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(baseQuantityKindItem); - } + writer.WriteStringValue(fileTypeItem); } - + writer.WriteEndArray(); - break; - case "baseunit": - var allowedVersionsForBaseUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("glossary"u8); - if(!allowedVersionsForBaseUnit.Contains(requestedVersion)) + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(glossaryItem); } - writer.WriteStartArray("baseUnit"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListBaseUnit) + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(baseUnitItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); + + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(parameterTypeItem); + } - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WriteStartArray("referenceSource"u8); + + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceSourceItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); } else { writer.WriteNullValue(); } - break; - case "constant": - var allowedVersionsForConstant = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); - if(!allowedVersionsForConstant.Contains(requestedVersion)) + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(ruleItem); } - writer.WriteStartArray("constant"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("scale"u8); - if(value is IEnumerable objectListConstant) + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) { - foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(constantItem); - } + writer.WriteStringValue(scaleItem); } - + writer.WriteEndArray(); - break; - case "definedcategory": - var allowedVersionsForDefinedCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); - if(!allowedVersionsForDefinedCategory.Contains(requestedVersion)) + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(unitItem); } - writer.WriteStartArray("definedCategory"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("unitPrefix"u8); - if(value is IEnumerable objectListDefinedCategory) + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) { - foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definedCategoryItem); - } + writer.WriteStringValue(unitPrefixItem); } - + writer.WriteEndArray(); + break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SiteReferenceDataLibrary for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("baseQuantityKind"u8); - if(value is IEnumerable objectListDefinition) + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteOrderedItem(baseQuantityKindItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("baseUnit"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(baseUnitItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(constantItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("definedCategory"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definedCategoryItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(definitionItem); } - - writer.WriteEndArray(); - break; - case "filetype": - var allowedVersionsForFileType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - if(!allowedVersionsForFileType.Contains(requestedVersion)) + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("fileType"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListFileType) + foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileTypeItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "glossary": - var allowedVersionsForGlossary = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("fileType"u8); - if(!allowedVersionsForGlossary.Contains(requestedVersion)) + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(fileTypeItem); } + writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); - if(value is IEnumerable objectListGlossary) + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) { - foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(glossaryItem); - } + writer.WriteStringValue(glossaryItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(siteReferenceDataLibrary.Name); + writer.WriteStartArray("parameterType"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(parameterTypeItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("referenceSource"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(referenceSourceItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("requiredRdl"u8); + + if(siteReferenceDataLibrary.RequiredRdl.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); + writer.WriteStartArray("rule"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(ruleItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("scale"u8); + + foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(scaleItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WriteStartArray("unit"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(unitItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("unitPrefix"u8); + + foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(unitPrefixItem); } + writer.WriteEndArray(); + break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SiteReferenceDataLibrary for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "parametertype": - var allowedVersionsForParameterType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("baseQuantityKind"u8); - if(!allowedVersionsForParameterType.Contains(requestedVersion)) + foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) { - return; + writer.WriteOrderedItem(baseQuantityKindItem); } - writer.WriteStartArray("parameterType"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("baseUnit"u8); - if(value is IEnumerable objectListParameterType) + foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) { - foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(parameterTypeItem); - } + writer.WriteStringValue(baseUnitItem); } - + writer.WriteEndArray(); - break; - case "referencesource": - var allowedVersionsForReferenceSource = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); + writer.WriteStartArray("constant"u8); - if(!allowedVersionsForReferenceSource.Contains(requestedVersion)) + foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(constantItem); } - writer.WriteStartArray("referenceSource"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("definedCategory"u8); - if(value is IEnumerable objectListReferenceSource) + foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) { - foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(referenceSourceItem); - } + writer.WriteStringValue(definedCategoryItem); } - + writer.WriteEndArray(); - break; - case "requiredrdl": - var allowedVersionsForRequiredRdl = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForRequiredRdl.Contains(requestedVersion)) + foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("requiredRdl"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else + writer.WriteStartArray("fileType"u8); + + foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(fileTypeItem); } - break; - case "rule": - var allowedVersionsForRule = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("glossary"u8); - if(!allowedVersionsForRule.Contains(requestedVersion)) + foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(glossaryItem); } - writer.WriteStartArray("rule"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListRule) + foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(ruleItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "scale": - var allowedVersionsForScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForScale.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("scale"u8); - - if(value is IEnumerable objectListScale) - { - foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(scaleItem); - } - } - - writer.WriteEndArray(); - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("shortName"u8); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("unit"u8); - - if(value is IEnumerable objectListUnit) - { - foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(unitItem); - } - } - - writer.WriteEndArray(); - break; - case "unitprefix": - var allowedVersionsForUnitPrefix = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnitPrefix.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("unitPrefix"u8); - - if(value is IEnumerable objectListUnitPrefix) - { - foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(unitPrefixItem); - } - } - - writer.WriteEndArray(); - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteReferenceDataLibrary"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SiteReferenceDataLibrary siteReferenceDataLibrary) - { - throw new ArgumentException("The thing shall be a SiteReferenceDataLibrary", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SiteReferenceDataLibrary since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("baseQuantityKind"u8); - - foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) - { - writer.WriteOrderedItem(baseQuantityKindItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("baseUnit"u8); - - foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(baseUnitItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); - writer.WriteStartArray("constant"u8); - - foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(constantItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("definedCategory"u8); - - foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definedCategoryItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(fileTypeItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("glossary"u8); - - foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(glossaryItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); writer.WritePropertyName("iid"u8); writer.WriteStringValue(siteReferenceDataLibrary.Iid); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(siteReferenceDataLibrary.Name); writer.WriteStartArray("parameterType"u8); @@ -876,6 +536,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) @@ -884,6 +545,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); if(siteReferenceDataLibrary.RequiredRdl.HasValue) @@ -905,6 +567,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) @@ -913,8 +576,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) @@ -923,6 +589,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) @@ -931,9 +598,21 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.1.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SiteReferenceDataLibrary for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(siteReferenceDataLibrary.Actor.HasValue) + { + writer.WriteStringValue(siteReferenceDataLibrary.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) @@ -942,6 +621,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseQuantityKind"u8); foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) @@ -950,6 +630,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("baseUnit"u8); foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) @@ -958,6 +639,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); writer.WriteStartArray("constant"u8); @@ -968,6 +650,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definedCategory"u8); foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) @@ -976,6 +659,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("definition"u8); foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) @@ -984,6 +668,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -992,6 +677,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -1000,6 +686,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("fileType"u8); foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) @@ -1008,6 +695,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("glossary"u8); foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) @@ -1016,6 +704,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -1024,6 +713,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(siteReferenceDataLibrary.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -1040,6 +730,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("referenceSource"u8); foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) @@ -1048,6 +739,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("requiredRdl"u8); if(siteReferenceDataLibrary.RequiredRdl.HasValue) @@ -1069,6 +761,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("scale"u8); foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) @@ -1077,8 +770,11 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); writer.WriteStringValue(siteReferenceDataLibrary.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) @@ -1087,6 +783,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("unitPrefix"u8); foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) @@ -1095,356 +792,553 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.2.0"); - writer.WriteStartArray("alias"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; } + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + writer.WriteEndArray(); + break; + case "basequantitykind": + if(!AllowedVersionsPerProperty["baseQuantityKind"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("baseQuantityKind"u8); - foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListBaseQuantityKind) { - writer.WriteOrderedItem(baseQuantityKindItem); + foreach(var baseQuantityKindItem in objectListBaseQuantityKind.OfType().OrderBy(x => x, this.OrderedItemComparer)) + { + writer.WriteOrderedItem(baseQuantityKindItem); + } } - + writer.WriteEndArray(); + break; + case "baseunit": + if(!AllowedVersionsPerProperty["baseUnit"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("baseUnit"u8); - foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListBaseUnit) { - writer.WriteStringValue(baseUnitItem); + foreach(var baseUnitItem in objectListBaseUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(baseUnitItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); - writer.WriteStartArray("constant"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + break; + case "constant": + if(!AllowedVersionsPerProperty["constant"].Contains(requestedVersion)) { - writer.WriteStringValue(constantItem); + return; } + writer.WriteStartArray("constant"u8); + + if(value is IEnumerable objectListConstant) + { + foreach(var constantItem in objectListConstant.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(constantItem); + } + } + writer.WriteEndArray(); + break; + case "definedcategory": + if(!AllowedVersionsPerProperty["definedCategory"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("definedCategory"u8); - foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinedCategory) { - writer.WriteStringValue(definedCategoryItem); + foreach(var definedCategoryItem in objectListDefinedCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definedCategoryItem); + } } - + writer.WriteEndArray(); + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("definition"u8); - foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(definitionItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "filetype": + if(!AllowedVersionsPerProperty["fileType"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("fileType"u8); - foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListFileType) { - writer.WriteStringValue(fileTypeItem); + foreach(var fileTypeItem in objectListFileType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(fileTypeItem); + } } - + writer.WriteEndArray(); + break; + case "glossary": + if(!AllowedVersionsPerProperty["glossary"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("glossary"u8); - foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListGlossary) { - writer.WriteStringValue(glossaryItem); + foreach(var glossaryItem in objectListGlossary.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(glossaryItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteReferenceDataLibrary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(siteReferenceDataLibrary.Name); - writer.WriteStartArray("parameterType"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(parameterTypeItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("referenceSource"u8); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } - foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(referenceSourceItem); + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("requiredRdl"u8); + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } - if(siteReferenceDataLibrary.RequiredRdl.HasValue) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + writer.WriteBooleanValue((bool)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); - writer.WriteStartArray("rule"u8); - - foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(ruleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("scale"u8); - - foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(scaleItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); - writer.WriteStartArray("unit"u8); - - foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(unitItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("unitPrefix"u8); - - foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(unitPrefixItem); + return; } - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SiteReferenceDataLibrary for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(siteReferenceDataLibrary.Actor.HasValue) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(siteReferenceDataLibrary.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in siteReferenceDataLibrary.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "parametertype": + if(!AllowedVersionsPerProperty["parameterType"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("baseQuantityKind"u8); + writer.WriteStartArray("parameterType"u8); - foreach(var baseQuantityKindItem in siteReferenceDataLibrary.BaseQuantityKind.OrderBy(x => x, this.OrderedItemComparer)) + if(value is IEnumerable objectListParameterType) { - writer.WriteOrderedItem(baseQuantityKindItem); + foreach(var parameterTypeItem in objectListParameterType.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(parameterTypeItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("baseUnit"u8); - - foreach(var baseUnitItem in siteReferenceDataLibrary.BaseUnit.OrderBy(x => x, this.GuidComparer)) + break; + case "referencesource": + if(!AllowedVersionsPerProperty["referenceSource"].Contains(requestedVersion)) { - writer.WriteStringValue(baseUnitItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ClassKind.ToString()); - writer.WriteStartArray("constant"u8); + writer.WriteStartArray("referenceSource"u8); - foreach(var constantItem in siteReferenceDataLibrary.Constant.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListReferenceSource) { - writer.WriteStringValue(constantItem); + foreach(var referenceSourceItem in objectListReferenceSource.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(referenceSourceItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("definedCategory"u8); - - foreach(var definedCategoryItem in siteReferenceDataLibrary.DefinedCategory.OrderBy(x => x, this.GuidComparer)) + break; + case "requiredrdl": + if(!AllowedVersionsPerProperty["requiredRdl"].Contains(requestedVersion)) { - writer.WriteStringValue(definedCategoryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in siteReferenceDataLibrary.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("requiredRdl"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in siteReferenceDataLibrary.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in siteReferenceDataLibrary.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("fileType"u8); - - foreach(var fileTypeItem in siteReferenceDataLibrary.FileType.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(fileTypeItem); + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("glossary"u8); - - foreach(var glossaryItem in siteReferenceDataLibrary.Glossary.OrderBy(x => x, this.GuidComparer)) + break; + case "rule": + if(!AllowedVersionsPerProperty["rule"].Contains(requestedVersion)) { - writer.WriteStringValue(glossaryItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("rule"u8); - foreach(var hyperLinkItem in siteReferenceDataLibrary.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRule) { - writer.WriteStringValue(hyperLinkItem); + foreach(var ruleItem in objectListRule.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(ruleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(siteReferenceDataLibrary.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(siteReferenceDataLibrary.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(siteReferenceDataLibrary.Name); - writer.WriteStartArray("parameterType"u8); - - foreach(var parameterTypeItem in siteReferenceDataLibrary.ParameterType.OrderBy(x => x, this.GuidComparer)) + break; + case "scale": + if(!AllowedVersionsPerProperty["scale"].Contains(requestedVersion)) { - writer.WriteStringValue(parameterTypeItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("referenceSource"u8); + writer.WriteStartArray("scale"u8); - foreach(var referenceSourceItem in siteReferenceDataLibrary.ReferenceSource.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListScale) { - writer.WriteStringValue(referenceSourceItem); + foreach(var scaleItem in objectListScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(scaleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("requiredRdl"u8); + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } - if(siteReferenceDataLibrary.RequiredRdl.HasValue) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(siteReferenceDataLibrary.RequiredRdl.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(siteReferenceDataLibrary.RevisionNumber); - writer.WriteStartArray("rule"u8); - - foreach(var ruleItem in siteReferenceDataLibrary.Rule.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(ruleItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("scale"u8); + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } - foreach(var scaleItem in siteReferenceDataLibrary.Scale.OrderBy(x => x, this.GuidComparer)) + break; + case "unit": + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { - writer.WriteStringValue(scaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(siteReferenceDataLibrary.ThingPreference); writer.WriteStartArray("unit"u8); - foreach(var unitItem in siteReferenceDataLibrary.Unit.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUnit) { - writer.WriteStringValue(unitItem); + foreach(var unitItem in objectListUnit.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitItem); + } } - + writer.WriteEndArray(); + break; + case "unitprefix": + if(!AllowedVersionsPerProperty["unitPrefix"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("unitPrefix"u8); - foreach(var unitPrefixItem in siteReferenceDataLibrary.UnitPrefix.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListUnitPrefix) { - writer.WriteStringValue(unitPrefixItem); + foreach(var unitPrefixItem in objectListUnitPrefix.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(unitPrefixItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SiteReferenceDataLibrary"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "baseQuantityKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "baseUnit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "constant", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definedCategory", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "fileType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "glossary", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "parameterType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "referenceSource", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "requiredRdl", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "rule", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "scale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "unitPrefix", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs index 96fb334f7..4bfe39b12 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SolutionSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,170 @@ namespace CDP4JsonSerializer /// public class SolutionSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not Solution solution) + { + throw new ArgumentException("The thing shall be a Solution", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Solution since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Solution for Version 1.1.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Solution for Version 1.2.0"); + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(solution.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Solution for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(solution.Actor.HasValue) + { + writer.WriteStringValue(solution.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("author"u8); + writer.WriteStringValue(solution.Author); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(solution.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(solution.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(solution.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(solution.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(solution.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(solution.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(solution.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +221,7 @@ public class SolutionSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +229,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +247,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "author": - var allowedVersionsForAuthor = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAuthor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["author"].Contains(requestedVersion)) { return; } @@ -111,14 +265,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +283,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +301,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -261,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -286,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -336,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,13 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -390,162 +468,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not Solution solution) - { - throw new ArgumentException("The thing shall be a Solution", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Solution since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.1.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(solution.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(solution.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(solution.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(solution.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(solution.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(solution.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(solution.RevisionNumber); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.2.0"); - writer.WritePropertyName("author"u8); - writer.WriteStringValue(solution.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(solution.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(solution.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(solution.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(solution.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(solution.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(solution.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(solution.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Solution for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(solution.Actor.HasValue) - { - writer.WriteStringValue(solution.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("author"u8); - writer.WriteStringValue(solution.Author); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(solution.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(solution.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(solution.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in solution.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in solution.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(solution.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(solution.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(solution.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(solution.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(solution.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(solution.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "author", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs index 411b0211e..eac937655 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/SpecializedQuantityKindSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,409 @@ namespace CDP4JsonSerializer public class SpecializedQuantityKindSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not SpecializedQuantityKind specializedQuantityKind) + { + throw new ArgumentException("The thing shall be a SpecializedQuantityKind", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of SpecializedQuantityKind since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing SpecializedQuantityKind for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(categoryItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(definitionItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(value is IEnumerable objectListAlias) + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(possibleScaleItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing SpecializedQuantityKind for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "defaultscale": - var allowedVersionsForDefaultScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefaultScale.Contains(requestedVersion)) + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("defaultScale"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(possibleScaleItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing SpecializedQuantityKind for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListDefinition) + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } + writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedPersonItem); } - + writer.WriteEndArray(); - break; - case "general": - var allowedVersionsForGeneral = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForGeneral.Contains(requestedVersion)) + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("general"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(possibleScaleItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(specializedQuantityKind.ThingPreference); break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing SpecializedQuantityKind for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(specializedQuantityKind.Actor.HasValue) { - return; + writer.WriteStringValue(specializedQuantityKind.Actor.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); + writer.WritePropertyName("defaultScale"u8); + writer.WriteStringValue(specializedQuantityKind.DefaultScale); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("general"u8); + writer.WriteStringValue(specializedQuantityKind.General); + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteBooleanValue((bool)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(specializedQuantityKind.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(specializedQuantityKind.Name); + writer.WriteStartArray("possibleScale"u8); + + foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(possibleScaleItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(specializedQuantityKind.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(specializedQuantityKind.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(specializedQuantityKind.ThingPreference); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue((Guid)value); } else { @@ -394,77 +461,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "possiblescale": - var allowedVersionsForPossibleScale = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForPossibleScale.Contains(requestedVersion)) + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("possibleScale"u8); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListPossibleScale) + if(value is IEnumerable objectListCategory) { - foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(possibleScaleItem); + writer.WriteStringValue(categoryItem); } } writer.WriteEndArray(); break; - case "quantitydimensionsymbol": - var allowedVersionsForQuantityDimensionSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForQuantityDimensionSymbol.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("quantityDimensionSymbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -472,25 +515,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + case "defaultscale": + if(!AllowedVersionsPerProperty["defaultScale"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("defaultScale"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -498,51 +533,71 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); break; - case "symbol": - var allowedVersionsForSymbol = new List + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "general": + if(!AllowedVersionsPerProperty["general"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("general"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -550,23 +605,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + writer.WriteStartArray("hyperLink"u8); + + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -574,363 +641,199 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the SpecializedQuantityKind"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not SpecializedQuantityKind specializedQuantityKind) - { - throw new ArgumentException("The thing shall be a SpecializedQuantityKind", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of SpecializedQuantityKind since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(specializedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("general"u8); - writer.WriteStringValue(specializedQuantityKind.General); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(specializedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(specializedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(specializedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(specializedQuantityKind.Symbol); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(categoryItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(specializedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("general"u8); - writer.WriteStringValue(specializedQuantityKind.General); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "possiblescale": + if(!AllowedVersionsPerProperty["possibleScale"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(specializedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(specializedQuantityKind.Name); writer.WriteStartArray("possibleScale"u8); - foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListPossibleScale) { - writer.WriteStringValue(possibleScaleItem); + foreach(var possibleScaleItem in objectListPossibleScale.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(possibleScaleItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(specializedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(specializedQuantityKind.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) + case "quantitydimensionsymbol": + if(!AllowedVersionsPerProperty["quantityDimensionSymbol"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("quantityDimensionSymbol"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(specializedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("general"u8); - writer.WriteStringValue(specializedQuantityKind.General); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(specializedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(specializedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(possibleScaleItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(specializedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(specializedQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(specializedQuantityKind.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing SpecializedQuantityKind for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(specializedQuantityKind.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(specializedQuantityKind.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in specializedQuantityKind.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in specializedQuantityKind.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(specializedQuantityKind.ClassKind.ToString()); - writer.WritePropertyName("defaultScale"u8); - writer.WriteStringValue(specializedQuantityKind.DefaultScale); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in specializedQuantityKind.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in specializedQuantityKind.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in specializedQuantityKind.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedPersonItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("general"u8); - writer.WriteStringValue(specializedQuantityKind.General); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in specializedQuantityKind.HyperLink.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(hyperLinkItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(specializedQuantityKind.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(specializedQuantityKind.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(specializedQuantityKind.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(specializedQuantityKind.Name); - writer.WriteStartArray("possibleScale"u8); - - foreach(var possibleScaleItem in specializedQuantityKind.PossibleScale.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(possibleScaleItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("quantityDimensionSymbol"u8); - writer.WriteStringValue(specializedQuantityKind.QuantityDimensionSymbol); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(specializedQuantityKind.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(specializedQuantityKind.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(specializedQuantityKind.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(specializedQuantityKind.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the SpecializedQuantityKind"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "defaultScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "general", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "possibleScale", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "quantityDimensionSymbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs index 336a62045..140d52943 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,522 +51,273 @@ namespace CDP4JsonSerializer public class StakeHolderValueMapSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not StakeHolderValueMap stakeHolderValueMap) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a StakeHolderValueMap", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of StakeHolderValueMap since Version is below 1.1.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMap for Version 1.1.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WriteStartArray("definition"u8); - - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("goal"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(goalItem); } - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "goal": - var allowedVersionsForGoal = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForGoal.Contains(requestedVersion)) + foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("goal"u8); - - if(value is IEnumerable objectListGoal) - { - foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(goalItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeHolderValueMap.Name); + writer.WriteStartArray("requirement"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(requirementItem); } - writer.WriteStartArray("hyperLink"u8); - - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); + writer.WriteStartArray("settings"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(settingsItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeHolderValueMap.ShortName); + writer.WriteStartArray("stakeholderValue"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderValueItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("valueGroup"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(valueGroupItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - break; - case "requirement": - var allowedVersionsForRequirement = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMap for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForRequirement.Contains(requestedVersion)) + foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("requirement"u8); - - if(value is IEnumerable objectListRequirement) - { - foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(requirementItem); - } - } - writer.WriteEndArray(); - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "settings": - var allowedVersionsForSettings = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForSettings.Contains(requestedVersion)) + foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("settings"u8); - - if(value is IEnumerable objectListSettings) - { - foreach(var settingsItem in objectListSettings.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(settingsItem); - } - } - writer.WriteEndArray(); - break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "stakeholdervalue": - var allowedVersionsForStakeholderValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("stakeholderValue"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("goal"u8); - if(value is IEnumerable objectListStakeholderValue) + foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) { - foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(stakeholderValueItem); - } + writer.WriteStringValue(goalItem); } - + writer.WriteEndArray(); - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeHolderValueMap.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeHolderValueMap.Name); + writer.WriteStartArray("requirement"u8); + + foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(requirementItem); } - break; - case "valuegroup": - var allowedVersionsForValueGroup = new List + writer.WriteEndArray(); + + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); + writer.WriteStartArray("settings"u8); + + foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStringValue(settingsItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeHolderValueMap.ShortName); + writer.WriteStartArray("stakeholderValue"u8); - if(!allowedVersionsForValueGroup.Contains(requestedVersion)) + foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderValueItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMap.ThingPreference); writer.WriteStartArray("valueGroup"u8); - if(value is IEnumerable objectListValueGroup) + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) { - foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(valueGroupItem); - } + writer.WriteStringValue(valueGroupItem); } - + writer.WriteEndArray(); + break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMap"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not StakeHolderValueMap stakeHolderValueMap) - { - throw new ArgumentException("The thing shall be a StakeHolderValueMap", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of StakeHolderValueMap since Version is below 1.1.0"); - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMap for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WriteStartObject(); + if(stakeHolderValueMap.Actor.HasValue) + { + writer.WriteStringValue(stakeHolderValueMap.Actor.Value); + } + else + { + writer.WriteNullValue(); + } - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.1.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) @@ -574,6 +326,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("category"u8); foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) @@ -582,6 +335,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -592,6 +346,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -600,6 +355,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -608,6 +364,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("goal"u8); foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) @@ -616,6 +373,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -624,6 +382,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(stakeHolderValueMap.Iid); writer.WritePropertyName("modifiedOn"u8); @@ -638,6 +397,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("revisionNumber"u8); writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); writer.WriteStartArray("settings"u8); @@ -648,252 +408,423 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("shortName"u8); writer.WriteStringValue(stakeHolderValueMap.ShortName); writer.WriteStartArray("stakeholderValue"u8); foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(stakeholderValueItem); + writer.WriteStringValue(stakeholderValueItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeHolderValueMap.ThingPreference); + writer.WriteStartArray("valueGroup"u8); + + foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) + { + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + } + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("category"u8); + + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "goal": + if(!AllowedVersionsPerProperty["goal"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("goal"u8); + + if(value is IEnumerable objectListGoal) + { + foreach(var goalItem in objectListGoal.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(goalItem); + } + } + + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; } - writer.WriteEndArray(); - writer.WriteStartArray("valueGroup"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(valueGroupItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("goal"u8); - - foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(goalItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeHolderValueMap.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeHolderValueMap.Name); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(requirementItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); - writer.WriteStartArray("settings"u8); - - foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(settingsItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeHolderValueMap.ShortName); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + break; + case "requirement": + if(!AllowedVersionsPerProperty["requirement"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderValueItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeHolderValueMap.ThingPreference); - writer.WriteStartArray("valueGroup"u8); + writer.WriteStartArray("requirement"u8); - foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListRequirement) { - writer.WriteStringValue(valueGroupItem); + foreach(var requirementItem in objectListRequirement.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(requirementItem); + } } - + writer.WriteEndArray(); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMap for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(stakeHolderValueMap.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(stakeHolderValueMap.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeHolderValueMap.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "settings": + if(!AllowedVersionsPerProperty["settings"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("settings"u8); - foreach(var categoryItem in stakeHolderValueMap.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListSettings) { - writer.WriteStringValue(categoryItem); + foreach(var settingsItem in objectListSettings.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(settingsItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeHolderValueMap.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeHolderValueMap.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeHolderValueMap.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeHolderValueMap.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("goal"u8); - - foreach(var goalItem in stakeHolderValueMap.Goal.OrderBy(x => x, this.GuidComparer)) + break; + case "stakeholdervalue": + if(!AllowedVersionsPerProperty["stakeholderValue"].Contains(requestedVersion)) { - writer.WriteStringValue(goalItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); + writer.WriteStartArray("stakeholderValue"u8); - foreach(var hyperLinkItem in stakeHolderValueMap.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListStakeholderValue) { - writer.WriteStringValue(hyperLinkItem); + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeHolderValueMap.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeHolderValueMap.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeHolderValueMap.Name); - writer.WriteStartArray("requirement"u8); - - foreach(var requirementItem in stakeHolderValueMap.Requirement.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(requirementItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeHolderValueMap.RevisionNumber); - writer.WriteStartArray("settings"u8); - - foreach(var settingsItem in stakeHolderValueMap.Settings.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(settingsItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeHolderValueMap.ShortName); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in stakeHolderValueMap.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + break; + case "valuegroup": + if(!AllowedVersionsPerProperty["valueGroup"].Contains(requestedVersion)) { - writer.WriteStringValue(stakeholderValueItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeHolderValueMap.ThingPreference); writer.WriteStartArray("valueGroup"u8); - foreach(var valueGroupItem in stakeHolderValueMap.ValueGroup.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListValueGroup) { - writer.WriteStringValue(valueGroupItem); + foreach(var valueGroupItem in objectListValueGroup.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(valueGroupItem); + } } - + writer.WriteEndArray(); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMap"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "goal", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "requirement", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "settings", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholderValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueGroup", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs index 5d4612705..9a0ecc249 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeHolderValueMapSettingsSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,296 +50,6 @@ namespace CDP4JsonSerializer /// public class StakeHolderValueMapSettingsSerializer : BaseThingSerializer, IThingSerializer { - /// - /// Serialize a value for a property into a - /// - /// The name of the property to serialize - /// The object value to serialize - /// The - /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) - { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("classKind"u8); - - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - - writer.WriteEndArray(); - break; - case "goaltovaluegrouprelationship": - var allowedVersionsForGoalToValueGroupRelationship = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForGoalToValueGroupRelationship.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("goalToValueGroupRelationship"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("iid"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "stakeholdervaluetorequirementrelationship": - var allowedVersionsForStakeholderValueToRequirementRelationship = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStakeholderValueToRequirementRelationship.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("thingPreference"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "valuegrouptostakeholdervaluerelationship": - var allowedVersionsForValueGroupToStakeholderValueRelationship = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValueGroupToStakeholderValueRelationship.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMapSettings"); - } - } - /// /// Serializes a into an /// @@ -365,7 +76,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM switch(requestedDataModelVersion.ToString(3)) { case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.1.0"); + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMapSettings for Version 1.1.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(stakeHolderValueMapSettings.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -376,6 +87,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -384,6 +96,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) @@ -425,7 +138,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM break; case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.2.0"); + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMapSettings for Version 1.2.0"); writer.WritePropertyName("classKind"u8); writer.WriteStringValue(stakeHolderValueMapSettings.ClassKind.ToString()); writer.WriteStartArray("excludedDomain"u8); @@ -436,6 +149,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -444,6 +158,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) @@ -487,7 +202,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM break; case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing StakeHolderValueMapSettings for Version 1.3.0"); + Logger.Log(LogLevel.Trace, "Serializing StakeHolderValueMapSettings for Version 1.3.0"); writer.WritePropertyName("actor"u8); if(stakeHolderValueMapSettings.Actor.HasValue) @@ -509,6 +224,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in stakeHolderValueMapSettings.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -517,6 +233,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("goalToValueGroupRelationship"u8); if(stakeHolderValueMapSettings.GoalToValueGroupRelationship.HasValue) @@ -565,6 +282,241 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteEndObject(); } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("classKind"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } + + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) + { + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + } + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); + break; + case "goaltovaluegrouprelationship": + if(!AllowedVersionsPerProperty["goalToValueGroupRelationship"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("goalToValueGroupRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("iid"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "stakeholdervaluetorequirementrelationship": + if(!AllowedVersionsPerProperty["stakeholderValueToRequirementRelationship"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("stakeholderValueToRequirementRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("thingPreference"u8); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "valuegrouptostakeholdervaluerelationship": + if(!AllowedVersionsPerProperty["valueGroupToStakeholderValueRelationship"].Contains(requestedVersion)) + { + return; + } + + writer.WritePropertyName("valueGroupToStakeholderValueRelationship"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + default: + throw new ArgumentException($"The requested property {propertyName} does not exist on the StakeHolderValueMapSettings"); + } + } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "goalToValueGroupRelationship", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholderValueToRequirementRelationship", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "valueGroupToStakeholderValueRelationship", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs index fcde18fc7..4e34a4882 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,334 +51,311 @@ namespace CDP4JsonSerializer public class StakeholderSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not Stakeholder stakeholder) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a Stakeholder", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Stakeholder since Version is below 1.1.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Stakeholder for Version 1.1.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(categoryItem); } - writer.WriteStartArray("category"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListCategory) + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedPersonItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); - if(value is IEnumerable objectListDefinition) + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(stakeholderValueItem); } - + writer.WriteEndArray(); + break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Stakeholder for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(stakeholderValueItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholder.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Stakeholder for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeholder.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(stakeholder.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholder.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("revisionNumber"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue(hyperLinkItem); } - else + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholder.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholder.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholder.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholder.ShortName); + writer.WriteStartArray("stakeholderValue"u8); + + foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(stakeholderValueItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholder.ThingPreference); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(!allowedVersionsForShortName.Contains(requestedVersion)) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -385,48 +363,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "stakeholdervalue": - var allowedVersionsForStakeholderValue = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStakeholderValue.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WriteStartArray("stakeholderValue"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListStakeholderValue) + if(value is IEnumerable objectListAlias) { - foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(stakeholderValueItem); + writer.WriteStringValue(aliasItem); } } writer.WriteEndArray(); break; - case "thingpreference": - var allowedVersionsForThingPreference = new List + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("category"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -434,270 +417,230 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Stakeholder"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Stakeholder stakeholder) - { - throw new ArgumentException("The thing shall be a Stakeholder", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Stakeholder since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); + writer.WriteStartArray("definition"u8); - foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue(categoryItem); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholder.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholder.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholder.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholder.ShortName); - writer.WriteStartArray("stakeholderValue"u8); + writer.WriteStartArray("hyperLink"u8); - foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(stakeholderValueItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholder.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholder.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholder.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholder.ShortName); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + + if(value != null) { - writer.WriteStringValue(stakeholderValueItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeholder.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Stakeholder for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(stakeholder.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(stakeholder.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholder.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeholder.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholder.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholder.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeholder.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "stakeholdervalue": + if(!AllowedVersionsPerProperty["stakeholderValue"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); + writer.WriteStartArray("stakeholderValue"u8); - foreach(var excludedPersonItem in stakeholder.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListStakeholderValue) { - writer.WriteStringValue(excludedPersonItem); + foreach(var stakeholderValueItem in objectListStakeholderValue.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(stakeholderValueItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholder.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholder.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholder.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholder.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholder.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholder.ShortName); - writer.WriteStartArray("stakeholderValue"u8); - - foreach(var stakeholderValueItem in stakeholder.StakeholderValue.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(stakeholderValueItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeholder.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Stakeholder"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "stakeholderValue", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs index 7a7afb846..5279e8a3d 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/StakeholderValueSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,260 @@ namespace CDP4JsonSerializer /// public class StakeholderValueSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not StakeholderValue stakeholderValue) + { + throw new ArgumentException("The thing shall be a StakeholderValue", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of StakeholderValue since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing StakeholderValue for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing StakeholderValue for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholderValue.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing StakeholderValue for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(stakeholderValue.Actor.HasValue) + { + writer.WriteStringValue(stakeholderValue.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(stakeholderValue.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(stakeholderValue.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(stakeholderValue.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(stakeholderValue.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(stakeholderValue.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +311,7 @@ public class StakeholderValueSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "alias": - var allowedVersionsForAlias = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } @@ -111,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -136,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -161,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "definition": - var allowedVersionsForDefinition = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } @@ -186,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } @@ -261,14 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +481,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +499,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -336,14 +517,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,14 +535,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +553,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,240 +576,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not StakeholderValue stakeholderValue) - { - throw new ArgumentException("The thing shall be a StakeholderValue", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of StakeholderValue since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholderValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholderValue.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholderValue.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholderValue.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholderValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholderValue.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholderValue.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholderValue.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeholderValue.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing StakeholderValue for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(stakeholderValue.Actor.HasValue) - { - writer.WriteStringValue(stakeholderValue.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in stakeholderValue.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in stakeholderValue.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(stakeholderValue.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in stakeholderValue.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in stakeholderValue.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in stakeholderValue.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in stakeholderValue.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(stakeholderValue.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(stakeholderValue.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(stakeholderValue.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(stakeholderValue.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(stakeholderValue.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(stakeholderValue.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs index 028bdf061..edd1133a9 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TelephoneNumberSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,193 @@ namespace CDP4JsonSerializer /// public class TelephoneNumberSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not TelephoneNumber telephoneNumber) + { + throw new ArgumentException("The thing shall be a TelephoneNumber", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of TelephoneNumber since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing TelephoneNumber for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing TelephoneNumber for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing TelephoneNumber for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(telephoneNumber.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing TelephoneNumber for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(telephoneNumber.Actor.HasValue) + { + writer.WriteStringValue(telephoneNumber.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(telephoneNumber.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(telephoneNumber.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(telephoneNumber.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(telephoneNumber.Value); + writer.WriteStartArray("vcardType"u8); + + foreach(var vcardTypeItem in telephoneNumber.VcardType) + { + writer.WriteStringValue(vcardTypeItem.ToString()); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +244,7 @@ public class TelephoneNumberSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +252,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +270,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +288,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +306,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +324,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +342,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +360,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,13 +378,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -263,15 +396,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -289,15 +414,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "vcardtype": - var allowedVersionsForVcardType = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForVcardType.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["vcardType"].Contains(requestedVersion)) { return; } @@ -320,181 +437,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not TelephoneNumber telephoneNumber) - { - throw new ArgumentException("The thing shall be a TelephoneNumber", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of TelephoneNumber since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(telephoneNumber.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(telephoneNumber.RevisionNumber); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(telephoneNumber.Value); - writer.WriteStartArray("vcardType"u8); - - foreach(var vcardTypeItem in telephoneNumber.VcardType) - { - writer.WriteStringValue(vcardTypeItem.ToString()); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(telephoneNumber.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(telephoneNumber.RevisionNumber); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(telephoneNumber.Value); - writer.WriteStartArray("vcardType"u8); - - foreach(var vcardTypeItem in telephoneNumber.VcardType) - { - writer.WriteStringValue(vcardTypeItem.ToString()); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(telephoneNumber.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(telephoneNumber.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(telephoneNumber.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(telephoneNumber.Value); - writer.WriteStartArray("vcardType"u8); - - foreach(var vcardTypeItem in telephoneNumber.VcardType) - { - writer.WriteStringValue(vcardTypeItem.ToString()); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing TelephoneNumber for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(telephoneNumber.Actor.HasValue) - { - writer.WriteStringValue(telephoneNumber.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(telephoneNumber.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in telephoneNumber.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in telephoneNumber.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(telephoneNumber.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(telephoneNumber.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(telephoneNumber.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(telephoneNumber.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(telephoneNumber.Value); - writer.WriteStartArray("vcardType"u8); - - foreach(var vcardTypeItem in telephoneNumber.VcardType) - { - writer.WriteStringValue(vcardTypeItem.ToString()); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "vcardType", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs index 14e1340b2..00c4ad377 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TermSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,424 +51,112 @@ namespace CDP4JsonSerializer public class TermSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); - - switch(propertyName.ToLower()) + if (thing is not Term term) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("actor"u8); - - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } + throw new ArgumentException("The thing shall be a Term", nameof(thing)); + } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of Term since Version is below 1.0.0"); + return; + } - if(!allowedVersionsForAlias.Contains(requestedVersion)) - { - return; - } + writer.WriteStartObject(); + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing Term for Version 1.0.0"); writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListAlias) - { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - } - - writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else - { - writer.WriteNullValue(); - } - - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListDefinition) - { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - } - - writer.WriteEndArray(); - break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedDomain"u8); - - if(value is IEnumerable objectListExcludedDomain) - { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - } - writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) - { - return; - } - - writer.WriteStartArray("excludedPerson"u8); - - if(value is IEnumerable objectListExcludedPerson) - { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - } - writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) - { - return; - } - writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) - { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - } - - writer.WriteEndArray(); - break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(hyperLinkItem); } - writer.WritePropertyName("iid"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) - { - return; - } - + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(term.Iid); writer.WritePropertyName("isDeprecated"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) - { - return; - } - - writer.WritePropertyName("modifiedOn"u8); - - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) - { - return; - } - + writer.WriteBooleanValue(term.IsDeprecated); writer.WritePropertyName("name"u8); - - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) - { - return; - } - + writer.WriteStringValue(term.Name); writer.WritePropertyName("revisionNumber"u8); - - if(value != null) - { - writer.WriteNumberValue((int)value); - } - else - { - writer.WriteNullValue(); - } - + writer.WriteNumberValue(term.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(term.ShortName); break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing Term for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("shortName"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(term.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("thingPreference"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else - { - writer.WriteNullValue(); - } - - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the Term"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not Term term) - { - throw new ArgumentException("The thing shall be a Term", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of Term since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(aliasItem); + writer.WriteStringValue(excludedDomainItem); } writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(term.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(excludedPersonItem); } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -476,10 +165,13 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(term.Iid); writer.WritePropertyName("isDeprecated"u8); writer.WriteBooleanValue(term.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(term.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); writer.WritePropertyName("name"u8); writer.WriteStringValue(term.Name); writer.WritePropertyName("revisionNumber"u8); @@ -487,8 +179,8 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("shortName"u8); writer.WriteStringValue(term.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.1.0"); + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing Term for Version 1.2.0"); writer.WriteStartArray("alias"u8); foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) @@ -497,6 +189,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(term.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -507,6 +200,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -515,6 +209,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -523,6 +218,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -531,6 +227,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(term.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -543,9 +240,22 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WriteNumberValue(term.RevisionNumber); writer.WritePropertyName("shortName"u8); writer.WriteStringValue(term.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(term.ThingPreference); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.2.0"); + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing Term for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(term.Actor.HasValue) + { + writer.WriteStringValue(term.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + writer.WriteStartArray("alias"u8); foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) @@ -554,6 +264,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("classKind"u8); writer.WriteStringValue(term.ClassKind.ToString()); writer.WriteStartArray("definition"u8); @@ -564,6 +275,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedDomain"u8); foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) @@ -572,6 +284,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("excludedPerson"u8); foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) @@ -580,6 +293,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) @@ -588,6 +302,7 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM } writer.WriteEndArray(); + writer.WritePropertyName("iid"u8); writer.WriteStringValue(term.Iid); writer.WritePropertyName("isDeprecated"u8); @@ -603,82 +318,304 @@ public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataM writer.WritePropertyName("thingPreference"u8); writer.WriteStringValue(term.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing Term for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } - if(term.Actor.HasValue) + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { - writer.WriteStringValue(term.Actor.Value); + return; + } + + writer.WritePropertyName("actor"u8); + + if(value != null) + { + writer.WriteStringValue((Guid)value); } else { writer.WriteNullValue(); } + break; + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("alias"u8); - foreach(var aliasItem in term.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue(aliasItem); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(term.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + + if(value != null) + { + writer.WriteStringValue(((ClassKind)value).ToString()); + } + else + { + writer.WriteNullValue(); + } - foreach(var definitionItem in term.Definition.OrderBy(x => x, this.GuidComparer)) + break; + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedDomain"u8); - foreach(var excludedDomainItem in term.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(excludedDomainItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("excludedPerson"u8); - foreach(var excludedPersonItem in term.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(excludedPersonItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in term.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("iid"u8); - writer.WriteStringValue(term.Iid); + + if(value != null) + { + writer.WriteStringValue((Guid)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(term.IsDeprecated); + + if(value != null) + { + writer.WriteBooleanValue((bool)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(term.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + + if(value != null) + { + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("name"u8); - writer.WriteStringValue(term.Name); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(term.RevisionNumber); + + if(value != null) + { + writer.WriteNumberValue((int)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(term.ShortName); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) + { + return; + } + writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(term.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the Term"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs index 9c1d07169..daafd885e 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TextParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,349 @@ namespace CDP4JsonSerializer public class TextParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not TextParameterType textParameterType) + { + throw new ArgumentException("The thing shall be a TextParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of TextParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing TextParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing TextParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing TextParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing TextParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(textParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(textParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(textParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(textParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textParameterType.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the TextParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not TextParameterType textParameterType) - { - throw new ArgumentException("The thing shall be a TextParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of TextParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(textParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(textParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(textParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(textParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(textParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(textParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(textParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing TextParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(textParameterType.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(textParameterType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in textParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in textParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in textParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(textParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(textParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(textParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the TextParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs index 168f24037..132af6d3b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TextualNoteSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,203 @@ namespace CDP4JsonSerializer /// public class TextualNoteSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not TextualNote textualNote) + { + throw new ArgumentException("The thing shall be a TextualNote", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of TextualNote since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing TextualNote for Version 1.1.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing TextualNote for Version 1.2.0"); + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textualNote.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing TextualNote for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(textualNote.Actor.HasValue) + { + writer.WriteStringValue(textualNote.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(textualNote.ClassKind.ToString()); + writer.WritePropertyName("content"u8); + writer.WriteStringValue(textualNote.Content); + writer.WritePropertyName("createdOn"u8); + writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(textualNote.Iid); + writer.WritePropertyName("languageCode"u8); + writer.WriteStringValue(textualNote.LanguageCode); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(textualNote.Name); + writer.WritePropertyName("owner"u8); + writer.WriteStringValue(textualNote.Owner); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(textualNote.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(textualNote.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(textualNote.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +254,7 @@ public class TextualNoteSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +262,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +280,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -111,14 +298,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -136,14 +316,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "content": - var allowedVersionsForContent = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForContent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["content"].Contains(requestedVersion)) { return; } @@ -161,14 +334,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "createdon": - var allowedVersionsForCreatedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCreatedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["createdOn"].Contains(requestedVersion)) { return; } @@ -186,14 +352,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +370,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +388,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -261,14 +406,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "languagecode": - var allowedVersionsForLanguageCode = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForLanguageCode.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["languageCode"].Contains(requestedVersion)) { return; } @@ -286,14 +424,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +442,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -336,14 +460,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "owner": - var allowedVersionsForOwner = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForOwner.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["owner"].Contains(requestedVersion)) { return; } @@ -361,14 +478,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -386,14 +496,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -411,13 +514,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -440,192 +537,26 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not TextualNote textualNote) - { - throw new ArgumentException("The thing shall be a TextualNote", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of TextualNote since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.1.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textualNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(textualNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textualNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(textualNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textualNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(textualNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textualNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textualNote.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.2.0"); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textualNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(textualNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textualNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(textualNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textualNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(textualNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textualNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textualNote.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(textualNote.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing TextualNote for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(textualNote.Actor.HasValue) - { - writer.WriteStringValue(textualNote.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in textualNote.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(textualNote.ClassKind.ToString()); - writer.WritePropertyName("content"u8); - writer.WriteStringValue(textualNote.Content); - writer.WritePropertyName("createdOn"u8); - writer.WriteStringValue(textualNote.CreatedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in textualNote.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in textualNote.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(textualNote.Iid); - writer.WritePropertyName("languageCode"u8); - writer.WriteStringValue(textualNote.LanguageCode); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(textualNote.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(textualNote.Name); - writer.WritePropertyName("owner"u8); - writer.WriteStringValue(textualNote.Owner); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(textualNote.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(textualNote.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(textualNote.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "content", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "createdOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "languageCode", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "owner", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs index a2f051dc4..aca7ec451 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/TimeOfDayParameterTypeSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,343 +51,349 @@ namespace CDP4JsonSerializer public class TimeOfDayParameterTypeSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not TimeOfDayParameterType timeOfDayParameterType) + { + throw new ArgumentException("The thing shall be a TimeOfDayParameterType", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of TimeOfDayParameterType since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing TimeOfDayParameterType for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((Guid)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListAlias) + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); break; - case "category": - var allowedVersionsForCategory = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing TimeOfDayParameterType for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForCategory.Contains(requestedVersion)) + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } + writer.WriteEndArray(); + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListCategory) + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((ClassKind)value).ToString()); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing TimeOfDayParameterType for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(categoryItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(timeOfDayParameterType.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) - { - return; - } + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing TimeOfDayParameterType for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - writer.WritePropertyName("iid"u8); - - if(value != null) + if(timeOfDayParameterType.Actor.HasValue) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(timeOfDayParameterType.Actor.Value); } else { writer.WriteNullValue(); } - break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("isDeprecated"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(categoryItem); } - break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WritePropertyName("modifiedOn"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); - } - else + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForName.Contains(requestedVersion)) + foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WritePropertyName("name"u8); + writer.WriteEndArray(); - if(value != null) - { - writer.WriteStringValue((string)value); - } - else + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(timeOfDayParameterType.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(timeOfDayParameterType.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(timeOfDayParameterType.ShortName); + writer.WritePropertyName("symbol"u8); + writer.WriteStringValue(timeOfDayParameterType.Symbol); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(timeOfDayParameterType.ThingPreference); break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); + + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); + writer.WritePropertyName("actor"u8); if(value != null) { - writer.WriteNumberValue((int)value); + writer.WriteStringValue((Guid)value); } else { @@ -394,51 +401,53 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); - - if(value != null) + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteStringValue((string)value); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - else + + writer.WriteEndArray(); + break; + case "category": + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - case "symbol": - var allowedVersionsForSymbol = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteStartArray("category"u8); - if(!allowedVersionsForSymbol.Contains(requestedVersion)) + if(value is IEnumerable objectListCategory) + { + foreach(var categoryItem in objectListCategory.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + } + + writer.WriteEndArray(); + break; + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("symbol"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -446,331 +455,249 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); - - if(value != null) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) { - writer.WriteStringValue((string)value); + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } - break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the TimeOfDayParameterType"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not TimeOfDayParameterType timeOfDayParameterType) - { - throw new ArgumentException("The thing shall be a TimeOfDayParameterType", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of TimeOfDayParameterType since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.0.0"); - writer.WriteStartArray("alias"u8); + writer.WriteStartArray("excludedDomain"u8); - foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteStringValue(aliasItem); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - + writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteStringValue(categoryItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); + writer.WriteStartArray("excludedPerson"u8); - foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListExcludedPerson) { - writer.WriteStringValue(definitionItem); + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } } - + writer.WriteEndArray(); + break; + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) + { + return; + } + writer.WriteStartArray("hyperLink"u8); - foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + if(value is IEnumerable objectListHyperLink) { - writer.WriteStringValue(hyperLinkItem); + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } } - + writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(timeOfDayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(timeOfDayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(timeOfDayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(timeOfDayParameterType.Symbol); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("iid"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((Guid)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("isDeprecated"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteBooleanValue((bool)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(timeOfDayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(timeOfDayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(timeOfDayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(timeOfDayParameterType.Symbol); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(timeOfDayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(timeOfDayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(timeOfDayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(timeOfDayParameterType.Symbol); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(timeOfDayParameterType.ThingPreference); break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing TimeOfDayParameterType for Version 1.3.0"); - writer.WritePropertyName("actor"u8); + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) + { + return; + } - if(timeOfDayParameterType.Actor.HasValue) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(timeOfDayParameterType.Actor.Value); + writer.WriteNumberValue((int)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in timeOfDayParameterType.Alias.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in timeOfDayParameterType.Category.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("shortName"u8); + + if(value != null) { - writer.WriteStringValue(categoryItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(timeOfDayParameterType.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in timeOfDayParameterType.Definition.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(definitionItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in timeOfDayParameterType.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "symbol": + if(!AllowedVersionsPerProperty["symbol"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in timeOfDayParameterType.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("symbol"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in timeOfDayParameterType.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(timeOfDayParameterType.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(timeOfDayParameterType.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(timeOfDayParameterType.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(timeOfDayParameterType.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(timeOfDayParameterType.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(timeOfDayParameterType.ShortName); - writer.WritePropertyName("symbol"u8); - writer.WriteStringValue(timeOfDayParameterType.Symbol); writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(timeOfDayParameterType.ThingPreference); + + if(value != null) + { + writer.WriteStringValue((string)value); + } + else + { + writer.WriteNullValue(); + } + break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the TimeOfDayParameterType"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "symbol", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs index 5e5c72687..5e29c196b 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitFactorSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class UnitFactorSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not UnitFactor unitFactor) + { + throw new ArgumentException("The thing shall be a UnitFactor", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UnitFactor since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing UnitFactor for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing UnitFactor for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing UnitFactor for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitFactor.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing UnitFactor for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(unitFactor.Actor.HasValue) + { + writer.WriteStringValue(unitFactor.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitFactor.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("exponent"u8); + writer.WriteStringValue(unitFactor.Exponent); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitFactor.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitFactor.RevisionNumber); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitFactor.ThingPreference); + writer.WritePropertyName("unit"u8); + writer.WriteStringValue(unitFactor.Unit); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class UnitFactorSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "exponent": - var allowedVersionsForExponent = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExponent.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["exponent"].Contains(requestedVersion)) { return; } @@ -188,15 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,14 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -239,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -265,13 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -289,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "unit": - var allowedVersionsForUnit = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForUnit.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["unit"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not UnitFactor unitFactor) - { - throw new ArgumentException("The thing shall be a UnitFactor", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of UnitFactor since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitFactor.ClassKind.ToString()); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(unitFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitFactor.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitFactor.RevisionNumber); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(unitFactor.Unit); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(unitFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitFactor.RevisionNumber); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(unitFactor.Unit); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(unitFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitFactor.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(unitFactor.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(unitFactor.Unit); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing UnitFactor for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(unitFactor.Actor.HasValue) - { - writer.WriteStringValue(unitFactor.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitFactor.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitFactor.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitFactor.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("exponent"u8); - writer.WriteStringValue(unitFactor.Exponent); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitFactor.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitFactor.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitFactor.RevisionNumber); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(unitFactor.ThingPreference); - writer.WritePropertyName("unit"u8); - writer.WriteStringValue(unitFactor.Unit); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "exponent", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "unit", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs index dfbf4c97d..9bed99333 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UnitPrefixSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -50,236 +51,309 @@ namespace CDP4JsonSerializer public class UnitPrefixSerializer : BaseThingSerializer, IThingSerializer { /// - /// Serialize a value for a property into a + /// Serializes a into an /// - /// The name of the property to serialize - /// The object value to serialize + /// The that have to be serialized /// The /// The that has been requested for the serialization - public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) { - var requestedVersion = requestedDataModelVersion.ToString(3); + if (thing is not UnitPrefix unitPrefix) + { + throw new ArgumentException("The thing shall be a UnitPrefix", nameof(thing)); + } - switch(propertyName.ToLower()) + if (requestedDataModelVersion < Version.Parse("1.0.0")) { - case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; + Logger.Log(LogLevel.Info, "Skipping serialization of UnitPrefix since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing UnitPrefix for Version 1.0.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForActor.Contains(requestedVersion)) + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("actor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((Guid)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); break; - case "alias": - var allowedVersionsForAlias = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing UnitPrefix for Version 1.1.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForAlias.Contains(requestedVersion)) + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WriteStartArray("alias"u8); + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); - if(value is IEnumerable objectListAlias) + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) { - foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } + writer.WriteStringValue(definitionItem); } - + writer.WriteEndArray(); - break; - case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedDomain"u8); - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedDomainItem); } - writer.WritePropertyName("classKind"u8); + writer.WriteEndArray(); - if(value != null) + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue(((ClassKind)value).ToString()); + writer.WriteStringValue(excludedPersonItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(hyperLinkItem); } + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); break; - case "conversionfactor": - var allowedVersionsForConversionFactor = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing UnitPrefix for Version 1.2.0"); + writer.WriteStartArray("alias"u8); - if(!allowedVersionsForConversionFactor.Contains(requestedVersion)) + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(aliasItem); } - writer.WritePropertyName("conversionFactor"u8); + writer.WriteEndArray(); - if(value != null) + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) { - writer.WriteStringValue((string)value); + writer.WriteStringValue(definitionItem); } - else + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - writer.WriteNullValue(); + writer.WriteStringValue(excludedDomainItem); } - break; - case "definition": - var allowedVersionsForDefinition = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } - writer.WriteStartArray("definition"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListDefinition) + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitPrefix.ThingPreference); break; - case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing UnitPrefix for Version 1.3.0"); + writer.WritePropertyName("actor"u8); - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(unitPrefix.Actor.HasValue) { - return; + writer.WriteStringValue(unitPrefix.Actor.Value); + } + else + { + writer.WriteNullValue(); } - writer.WriteStartArray("excludedDomain"u8); + writer.WriteStartArray("alias"u8); - if(value is IEnumerable objectListExcludedDomain) + foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } + writer.WriteStringValue(aliasItem); } - + writer.WriteEndArray(); - break; - case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(unitPrefix.ClassKind.ToString()); + writer.WritePropertyName("conversionFactor"u8); + writer.WriteStringValue(unitPrefix.ConversionFactor); + writer.WriteStartArray("definition"u8); - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(definitionItem); } - writer.WriteStartArray("excludedPerson"u8); + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); - if(value is IEnumerable objectListExcludedPerson) + foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) { - foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } + writer.WriteStringValue(excludedDomainItem); } - + writer.WriteEndArray(); - break; - case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + + writer.WriteStartArray("excludedPerson"u8); - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) { - return; + writer.WriteStringValue(excludedPersonItem); } + writer.WriteEndArray(); + writer.WriteStartArray("hyperLink"u8); - if(value is IEnumerable objectListHyperLink) + foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) { - foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } + writer.WriteStringValue(hyperLinkItem); } - + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(unitPrefix.Iid); + writer.WritePropertyName("isDeprecated"u8); + writer.WriteBooleanValue(unitPrefix.IsDeprecated); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(unitPrefix.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(unitPrefix.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(unitPrefix.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(unitPrefix.ThingPreference); break; - case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + + /// + /// Serialize a value for a property into a + /// + /// The name of the property to serialize + /// The object value to serialize + /// The + /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a + public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + var requestedVersion = requestedDataModelVersion.ToString(3); - if(!allowedVersionsForIid.Contains(requestedVersion)) + switch(propertyName.ToLower()) + { + case "actor": + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("iid"u8); + writer.WritePropertyName("actor"u8); if(value != null) { @@ -291,50 +365,35 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "isdeprecated": - var allowedVersionsForIsDeprecated = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsDeprecated.Contains(requestedVersion)) + case "alias": + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("isDeprecated"u8); - - if(value != null) - { - writer.WriteBooleanValue((bool)value); - } - else + writer.WriteStartArray("alias"u8); + + if(value is IEnumerable objectListAlias) { - writer.WriteNullValue(); + foreach(var aliasItem in objectListAlias.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } } - + + writer.WriteEndArray(); break; - case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + case "classkind": + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("modifiedOn"u8); + writer.WritePropertyName("classKind"u8); if(value != null) { - writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); + writer.WriteStringValue(((ClassKind)value).ToString()); } else { @@ -342,21 +401,13 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "name": - var allowedVersionsForName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + case "conversionfactor": + if(!AllowedVersionsPerProperty["conversionFactor"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("name"u8); + writer.WritePropertyName("conversionFactor"u8); if(value != null) { @@ -368,51 +419,89 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "revisionnumber": - var allowedVersionsForRevisionNumber = new List + case "definition": + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + writer.WriteStartArray("definition"u8); + + if(value is IEnumerable objectListDefinition) + { + foreach(var definitionItem in objectListDefinition.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + } + + writer.WriteEndArray(); + break; + case "excludeddomain": + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("revisionNumber"u8); - - if(value != null) + writer.WriteStartArray("excludedDomain"u8); + + if(value is IEnumerable objectListExcludedDomain) { - writer.WriteNumberValue((int)value); + foreach(var excludedDomainItem in objectListExcludedDomain.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } } - else + + writer.WriteEndArray(); + break; + case "excludedperson": + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { - writer.WriteNullValue(); + return; } + writer.WriteStartArray("excludedPerson"u8); + + if(value is IEnumerable objectListExcludedPerson) + { + foreach(var excludedPersonItem in objectListExcludedPerson.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + } + + writer.WriteEndArray(); break; - case "shortname": - var allowedVersionsForShortName = new List + case "hyperlink": + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; + return; + } + + writer.WriteStartArray("hyperLink"u8); - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(value is IEnumerable objectListHyperLink) + { + foreach(var hyperLinkItem in objectListHyperLink.OfType().OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + } + + writer.WriteEndArray(); + break; + case "iid": + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("shortName"u8); + writer.WritePropertyName("iid"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteStringValue((Guid)value); } else { @@ -420,23 +509,17 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + case "isdeprecated": + if(!AllowedVersionsPerProperty["isDeprecated"].Contains(requestedVersion)) { return; } - writer.WritePropertyName("thingPreference"u8); + writer.WritePropertyName("isDeprecated"u8); if(value != null) { - writer.WriteStringValue((string)value); + writer.WriteBooleanValue((bool)value); } else { @@ -444,275 +527,122 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } break; - default: - throw new ArgumentException($"The requested property {propertyName} does not exist on the UnitPrefix"); - } - } - - /// - /// Serializes a into an - /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) - { - if (thing is not UnitPrefix unitPrefix) - { - throw new ArgumentException("The thing shall be a UnitPrefix", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of UnitPrefix since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.0.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) + case "modifiedon": + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { - writer.WriteStringValue(aliasItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitPrefix.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(unitPrefix.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("modifiedOn"u8); + + if(value != null) { - writer.WriteStringValue(definitionItem); + writer.WriteStringValue(((DateTime)value).ToString(SerializerHelper.DateTimeFormat)); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitPrefix.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(unitPrefix.IsDeprecated); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(unitPrefix.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitPrefix.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(unitPrefix.ShortName); break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitPrefix.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(unitPrefix.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + case "name": + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("name"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitPrefix.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(unitPrefix.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(unitPrefix.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitPrefix.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(unitPrefix.ShortName); break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitPrefix.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(unitPrefix.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) + case "revisionnumber": + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { - writer.WriteStringValue(definitionItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("revisionNumber"u8); + + if(value != null) { - writer.WriteStringValue(excludedDomainItem); + writer.WriteNumberValue((int)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(excludedPersonItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + break; + case "shortname": + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { - writer.WriteStringValue(hyperLinkItem); + return; } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitPrefix.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(unitPrefix.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(unitPrefix.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitPrefix.RevisionNumber); writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(unitPrefix.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(unitPrefix.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing UnitPrefix for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(unitPrefix.Actor.HasValue) + + if(value != null) { - writer.WriteStringValue(unitPrefix.Actor.Value); + writer.WriteStringValue((string)value); } else { writer.WriteNullValue(); } - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in unitPrefix.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(unitPrefix.ClassKind.ToString()); - writer.WritePropertyName("conversionFactor"u8); - writer.WriteStringValue(unitPrefix.ConversionFactor); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in unitPrefix.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in unitPrefix.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + break; + case "thingpreference": + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { - writer.WriteStringValue(excludedDomainItem); + return; } - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in unitPrefix.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + writer.WritePropertyName("thingPreference"u8); + + if(value != null) { - writer.WriteStringValue(excludedPersonItem); + writer.WriteStringValue((string)value); } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in unitPrefix.HyperLink.OrderBy(x => x, this.GuidComparer)) + else { - writer.WriteStringValue(hyperLinkItem); + writer.WriteNullValue(); } - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(unitPrefix.Iid); - writer.WritePropertyName("isDeprecated"u8); - writer.WriteBooleanValue(unitPrefix.IsDeprecated); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(unitPrefix.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(unitPrefix.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(unitPrefix.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(unitPrefix.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(unitPrefix.ThingPreference); break; default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + throw new ArgumentException($"The requested property {propertyName} does not exist on the UnitPrefix"); } - - writer.WriteEndObject(); } + + /// + /// Gets the association between a name of a property and all versions where that property is defined + /// + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() + { + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "conversionFactor", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isDeprecated", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs index 2e84713ae..017bf8548 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UserPreferenceSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,165 @@ namespace CDP4JsonSerializer /// public class UserPreferenceSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not UserPreference userPreference) + { + throw new ArgumentException("The thing shall be a UserPreference", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UserPreference since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing UserPreference for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing UserPreference for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing UserPreference for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userPreference.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing UserPreference for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(userPreference.Actor.HasValue) + { + writer.WriteStringValue(userPreference.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userPreference.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userPreference.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userPreference.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(userPreference.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userPreference.ThingPreference); + writer.WritePropertyName("value"u8); + writer.WriteStringValue(userPreference.Value); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +216,7 @@ public class UserPreferenceSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +224,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +242,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +260,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +278,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +296,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -188,14 +314,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -213,15 +332,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -239,15 +350,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -265,13 +368,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -289,15 +386,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "value": - var allowedVersionsForValue = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForValue.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["value"].Contains(requestedVersion)) { return; } @@ -320,157 +409,21 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not UserPreference userPreference) - { - throw new ArgumentException("The thing shall be a UserPreference", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of UserPreference since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userPreference.ClassKind.ToString()); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userPreference.Iid); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userPreference.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(userPreference.ShortName); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(userPreference.Value); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userPreference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userPreference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userPreference.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(userPreference.ShortName); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(userPreference.Value); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userPreference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userPreference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userPreference.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(userPreference.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(userPreference.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(userPreference.Value); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing UserPreference for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(userPreference.Actor.HasValue) - { - writer.WriteStringValue(userPreference.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userPreference.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userPreference.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userPreference.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userPreference.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userPreference.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userPreference.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(userPreference.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(userPreference.ThingPreference); - writer.WritePropertyName("value"u8); - writer.WriteStringValue(userPreference.Value); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "value", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs index 2341cbf1f..e7d7b52e7 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/UserRuleVerificationSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,253 @@ namespace CDP4JsonSerializer /// public class UserRuleVerificationSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not UserRuleVerification userRuleVerification) + { + throw new ArgumentException("The thing shall be a UserRuleVerification", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.0.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of UserRuleVerification since Version is below 1.0.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.0.0": + Logger.Log(LogLevel.Trace, "Serializing UserRuleVerification for Version 1.0.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing UserRuleVerification for Version 1.1.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing UserRuleVerification for Version 1.2.0"); + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing UserRuleVerification for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(userRuleVerification.Actor.HasValue) + { + writer.WriteStringValue(userRuleVerification.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("executedOn"u8); + + if(userRuleVerification.ExecutedOn.HasValue) + { + writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); + } + else + { + writer.WriteNullValue(); + } + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(userRuleVerification.Iid); + writer.WritePropertyName("isActive"u8); + writer.WriteBooleanValue(userRuleVerification.IsActive); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(userRuleVerification.RevisionNumber); + writer.WritePropertyName("rule"u8); + writer.WriteStringValue(userRuleVerification.Rule); + writer.WritePropertyName("status"u8); + writer.WriteStringValue(userRuleVerification.Status.ToString()); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(userRuleVerification.ThingPreference); + writer.WriteStartArray("violation"u8); + + foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(violationItem); + } + + writer.WriteEndArray(); + + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +304,7 @@ public class UserRuleVerificationSerializer : BaseThingSerializer, IThingSeriali /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +312,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,15 +330,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -112,14 +348,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -137,14 +366,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -162,15 +384,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "executedon": - var allowedVersionsForExecutedOn = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExecutedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["executedOn"].Contains(requestedVersion)) { return; } @@ -188,15 +402,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "iid": - var allowedVersionsForIid = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -214,15 +420,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "isactive": - var allowedVersionsForIsActive = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIsActive.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["isActive"].Contains(requestedVersion)) { return; } @@ -240,14 +438,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -265,15 +456,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -291,15 +474,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "rule": - var allowedVersionsForRule = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRule.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["rule"].Contains(requestedVersion)) { return; } @@ -317,15 +492,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "status": - var allowedVersionsForStatus = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForStatus.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["status"].Contains(requestedVersion)) { return; } @@ -343,13 +510,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -367,15 +528,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "violation": - var allowedVersionsForViolation = new List - { - "1.0.0", - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForViolation.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["violation"].Contains(requestedVersion)) { return; } @@ -398,241 +551,24 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not UserRuleVerification userRuleVerification) - { - throw new ArgumentException("The thing shall be a UserRuleVerification", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.0.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of UserRuleVerification since Version is below 1.0.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.0.0": - Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.0.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); - writer.WritePropertyName("executedOn"u8); - - if(userRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(userRuleVerification.IsActive); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userRuleVerification.RevisionNumber); - writer.WritePropertyName("rule"u8); - writer.WriteStringValue(userRuleVerification.Rule); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(userRuleVerification.Status.ToString()); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.1.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(userRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(userRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userRuleVerification.RevisionNumber); - writer.WritePropertyName("rule"u8); - writer.WriteStringValue(userRuleVerification.Rule); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(userRuleVerification.Status.ToString()); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.2.0"); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(userRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(userRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userRuleVerification.RevisionNumber); - writer.WritePropertyName("rule"u8); - writer.WriteStringValue(userRuleVerification.Rule); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(userRuleVerification.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(userRuleVerification.ThingPreference); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing UserRuleVerification for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(userRuleVerification.Actor.HasValue) - { - writer.WriteStringValue(userRuleVerification.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(userRuleVerification.ClassKind.ToString()); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in userRuleVerification.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in userRuleVerification.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("executedOn"u8); - - if(userRuleVerification.ExecutedOn.HasValue) - { - writer.WriteStringValue(userRuleVerification.ExecutedOn.Value.ToString(SerializerHelper.DateTimeFormat)); - } - else - { - writer.WriteNullValue(); - } - - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(userRuleVerification.Iid); - writer.WritePropertyName("isActive"u8); - writer.WriteBooleanValue(userRuleVerification.IsActive); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(userRuleVerification.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(userRuleVerification.RevisionNumber); - writer.WritePropertyName("rule"u8); - writer.WriteStringValue(userRuleVerification.Rule); - writer.WritePropertyName("status"u8); - writer.WriteStringValue(userRuleVerification.Status.ToString()); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(userRuleVerification.ThingPreference); - writer.WriteStartArray("violation"u8); - - foreach(var violationItem in userRuleVerification.Violation.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(violationItem); - } - - writer.WriteEndArray(); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "classKind", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "executedOn", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "isActive", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "rule", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "status", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + { "violation", new []{ "1.0.0", "1.1.0", "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs b/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs index 81d529ef1..9841c2313 100644 --- a/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs +++ b/CDP4JsonSerializer/AutoGenDtoSerializer/ValueGroupSerializer.cs @@ -33,6 +33,7 @@ namespace CDP4JsonSerializer using System.Linq; using System.Text.Json; + using CDP4Common; using CDP4Common.CommonData; using CDP4Common.EngineeringModelData; using CDP4Common.ReportingData; @@ -49,6 +50,260 @@ namespace CDP4JsonSerializer /// public class ValueGroupSerializer : BaseThingSerializer, IThingSerializer { + /// + /// Serializes a into an + /// + /// The that have to be serialized + /// The + /// The that has been requested for the serialization + /// If the provided is not an + /// If the provided is not supported + public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + { + if (thing is not ValueGroup valueGroup) + { + throw new ArgumentException("The thing shall be a ValueGroup", nameof(thing)); + } + + if (requestedDataModelVersion < Version.Parse("1.1.0")) + { + Logger.Log(LogLevel.Info, "Skipping serialization of ValueGroup since Version is below 1.1.0"); + return; + } + + writer.WriteStartObject(); + + switch(requestedDataModelVersion.ToString(3)) + { + case "1.1.0": + Logger.Log(LogLevel.Trace, "Serializing ValueGroup for Version 1.1.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + break; + case "1.2.0": + Logger.Log(LogLevel.Trace, "Serializing ValueGroup for Version 1.2.0"); + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(valueGroup.ThingPreference); + break; + case "1.3.0": + Logger.Log(LogLevel.Trace, "Serializing ValueGroup for Version 1.3.0"); + writer.WritePropertyName("actor"u8); + + if(valueGroup.Actor.HasValue) + { + writer.WriteStringValue(valueGroup.Actor.Value); + } + else + { + writer.WriteNullValue(); + } + + writer.WriteStartArray("alias"u8); + + foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(aliasItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("category"u8); + + foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(categoryItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("classKind"u8); + writer.WriteStringValue(valueGroup.ClassKind.ToString()); + writer.WriteStartArray("definition"u8); + + foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(definitionItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedDomain"u8); + + foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedDomainItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("excludedPerson"u8); + + foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(excludedPersonItem); + } + + writer.WriteEndArray(); + + writer.WriteStartArray("hyperLink"u8); + + foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) + { + writer.WriteStringValue(hyperLinkItem); + } + + writer.WriteEndArray(); + + writer.WritePropertyName("iid"u8); + writer.WriteStringValue(valueGroup.Iid); + writer.WritePropertyName("modifiedOn"u8); + writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); + writer.WritePropertyName("name"u8); + writer.WriteStringValue(valueGroup.Name); + writer.WritePropertyName("revisionNumber"u8); + writer.WriteNumberValue(valueGroup.RevisionNumber); + writer.WritePropertyName("shortName"u8); + writer.WriteStringValue(valueGroup.ShortName); + writer.WritePropertyName("thingPreference"u8); + writer.WriteStringValue(valueGroup.ThingPreference); + break; + default: + throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); + } + + writer.WriteEndObject(); + } + /// /// Serialize a value for a property into a /// @@ -56,6 +311,7 @@ public class ValueGroupSerializer : BaseThingSerializer, IThingSerializer /// The object value to serialize /// The /// The that has been requested for the serialization + /// This method should only be used in the scope of serializing a public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer, Version requestedDataModelVersion) { var requestedVersion = requestedDataModelVersion.ToString(3); @@ -63,12 +319,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter switch(propertyName.ToLower()) { case "actor": - var allowedVersionsForActor = new List - { - "1.3.0", - }; - - if(!allowedVersionsForActor.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["actor"].Contains(requestedVersion)) { return; } @@ -86,14 +337,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "alias": - var allowedVersionsForAlias = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForAlias.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["alias"].Contains(requestedVersion)) { return; } @@ -111,14 +355,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "category": - var allowedVersionsForCategory = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForCategory.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["category"].Contains(requestedVersion)) { return; } @@ -136,14 +373,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "classkind": - var allowedVersionsForClassKind = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForClassKind.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["classKind"].Contains(requestedVersion)) { return; } @@ -161,14 +391,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "definition": - var allowedVersionsForDefinition = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForDefinition.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["definition"].Contains(requestedVersion)) { return; } @@ -186,14 +409,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludeddomain": - var allowedVersionsForExcludedDomain = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedDomain.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedDomain"].Contains(requestedVersion)) { return; } @@ -211,14 +427,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "excludedperson": - var allowedVersionsForExcludedPerson = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForExcludedPerson.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["excludedPerson"].Contains(requestedVersion)) { return; } @@ -236,14 +445,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "hyperlink": - var allowedVersionsForHyperLink = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForHyperLink.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["hyperLink"].Contains(requestedVersion)) { return; } @@ -261,14 +463,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter writer.WriteEndArray(); break; case "iid": - var allowedVersionsForIid = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForIid.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["iid"].Contains(requestedVersion)) { return; } @@ -286,14 +481,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "modifiedon": - var allowedVersionsForModifiedOn = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForModifiedOn.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["modifiedOn"].Contains(requestedVersion)) { return; } @@ -311,14 +499,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "name": - var allowedVersionsForName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["name"].Contains(requestedVersion)) { return; } @@ -336,14 +517,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "revisionnumber": - var allowedVersionsForRevisionNumber = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForRevisionNumber.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["revisionNumber"].Contains(requestedVersion)) { return; } @@ -361,14 +535,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "shortname": - var allowedVersionsForShortName = new List - { - "1.1.0", - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForShortName.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["shortName"].Contains(requestedVersion)) { return; } @@ -386,13 +553,7 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter break; case "thingpreference": - var allowedVersionsForThingPreference = new List - { - "1.2.0", - "1.3.0", - }; - - if(!allowedVersionsForThingPreference.Contains(requestedVersion)) + if(!AllowedVersionsPerProperty["thingPreference"].Contains(requestedVersion)) { return; } @@ -415,240 +576,25 @@ public void SerializeProperty(string propertyName, object value, Utf8JsonWriter } /// - /// Serializes a into an + /// Gets the association between a name of a property and all versions where that property is defined /// - /// The that have to be serialized - /// The - /// The that has been requested for the serialization - /// If the provided is not an - /// If the provided is not supported - public void Serialize(Thing thing, Utf8JsonWriter writer, Version requestedDataModelVersion) + private static readonly IReadOnlyDictionary> AllowedVersionsPerProperty = new Dictionary>() { - if (thing is not ValueGroup valueGroup) - { - throw new ArgumentException("The thing shall be a ValueGroup", nameof(thing)); - } - - if (requestedDataModelVersion < Version.Parse("1.1.0")) - { - Logger.Log(LogLevel.Info, "Skipping serialization of ValueGroup since Version is below 1.1.0"); - return; - } - - writer.WriteStartObject(); - - switch(requestedDataModelVersion.ToString(3)) - { - case "1.1.0": - Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.1.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(valueGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(valueGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(valueGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(valueGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(valueGroup.ShortName); - break; - case "1.2.0": - Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.2.0"); - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(valueGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(valueGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(valueGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(valueGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(valueGroup.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(valueGroup.ThingPreference); - break; - case "1.3.0": - Logger.Log(LogLevel.Debug, "Serializing ValueGroup for Version 1.3.0"); - writer.WritePropertyName("actor"u8); - - if(valueGroup.Actor.HasValue) - { - writer.WriteStringValue(valueGroup.Actor.Value); - } - else - { - writer.WriteNullValue(); - } - - writer.WriteStartArray("alias"u8); - - foreach(var aliasItem in valueGroup.Alias.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(aliasItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("category"u8); - - foreach(var categoryItem in valueGroup.Category.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(categoryItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("classKind"u8); - writer.WriteStringValue(valueGroup.ClassKind.ToString()); - writer.WriteStartArray("definition"u8); - - foreach(var definitionItem in valueGroup.Definition.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(definitionItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedDomain"u8); - - foreach(var excludedDomainItem in valueGroup.ExcludedDomain.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedDomainItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("excludedPerson"u8); - - foreach(var excludedPersonItem in valueGroup.ExcludedPerson.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(excludedPersonItem); - } - - writer.WriteEndArray(); - writer.WriteStartArray("hyperLink"u8); - - foreach(var hyperLinkItem in valueGroup.HyperLink.OrderBy(x => x, this.GuidComparer)) - { - writer.WriteStringValue(hyperLinkItem); - } - - writer.WriteEndArray(); - writer.WritePropertyName("iid"u8); - writer.WriteStringValue(valueGroup.Iid); - writer.WritePropertyName("modifiedOn"u8); - writer.WriteStringValue(valueGroup.ModifiedOn.ToString(SerializerHelper.DateTimeFormat)); - writer.WritePropertyName("name"u8); - writer.WriteStringValue(valueGroup.Name); - writer.WritePropertyName("revisionNumber"u8); - writer.WriteNumberValue(valueGroup.RevisionNumber); - writer.WritePropertyName("shortName"u8); - writer.WriteStringValue(valueGroup.ShortName); - writer.WritePropertyName("thingPreference"u8); - writer.WriteStringValue(valueGroup.ThingPreference); - break; - default: - throw new NotSupportedException($"The provided version {requestedDataModelVersion.ToString(3)} is not supported"); - } - - writer.WriteEndObject(); - } + { "actor", new []{ "1.3.0" }}, + { "alias", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "category", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "classKind", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "definition", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedDomain", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "excludedPerson", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "hyperLink", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "iid", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "modifiedOn", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "name", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "revisionNumber", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "shortName", new []{ "1.1.0", "1.2.0", "1.3.0" }}, + { "thingPreference", new []{ "1.2.0", "1.3.0" }}, + }; } } diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index e2ec98c55..c989dc7b2 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -22,6 +22,7 @@ [BUMP] To CDP4Common 26.6.0 + README.md 11.0 diff --git a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs index 02d0ce7e4..6d469df8d 100644 --- a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs @@ -140,30 +140,6 @@ public void Verify_that_serialization_of_Post_Operation_returns_expected_result( private class TestPostOperation : PostOperation { - public override void ConstructFromOperation(Operation operation) - { - throw new NotImplementedException(); - } - - /// - /// Gets or sets the collection of DTOs to delete. - /// - public override List Delete { get; set; } - - /// - /// Gets or sets the collection of DTOs to create. - /// - public override List Create { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Update { get; set; } - - /// - /// Gets or sets the collection of DTOs to update. - /// - public override List Copy { get; set; } } } } From b1227a4f495ec768daa79cad6033063b4188442e Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 14:47:40 +0100 Subject: [PATCH 13/17] Fix deserialization of OrderedItem --- CDP4JsonSerializer/Helper/SerializerHelper.cs | 29 ++++++++++++------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/CDP4JsonSerializer/Helper/SerializerHelper.cs b/CDP4JsonSerializer/Helper/SerializerHelper.cs index c1f22cfc9..01f7955eb 100644 --- a/CDP4JsonSerializer/Helper/SerializerHelper.cs +++ b/CDP4JsonSerializer/Helper/SerializerHelper.cs @@ -135,23 +135,30 @@ public static IEnumerable ToOrderedItemCollection(this JsonElement foreach (var prop in jsonToken.EnumerateArray()) { - var keyProp = prop.GetProperty("k"); - var valueKind = keyProp.ValueKind; - var key = long.MinValue; + var valueProp = prop.GetProperty("v"); + var valueKind = valueProp.ValueKind; - if (valueKind == JsonValueKind.String) + object valueToAssign = valueKind switch { - key = Convert.ToInt64(keyProp.GetString()); - } - else if (valueKind == JsonValueKind.Number) + JsonValueKind.String => valueProp.GetString(), + JsonValueKind.Number => valueProp.GetInt64(), + _ => null + }; + + var keyProp = prop.GetProperty("k"); + valueKind = keyProp.ValueKind; + + var keyValue = valueKind switch { - key = keyProp.GetInt64(); - } + JsonValueKind.String => long.Parse(keyProp.GetString()!), + JsonValueKind.Number => keyProp.GetInt64(), + _ => long.MinValue + }; var orderedItem = new OrderedItem { - K = key, - V = prop.GetProperty("v").GetString(), + K = keyValue, + V = valueToAssign }; if (prop.TryGetProperty("m", out var value) && value.ValueKind != JsonValueKind.Null) From 3b03b1fcdc61bef8db63de56c8ade663a12aebc2 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 15:07:53 +0100 Subject: [PATCH 14/17] Remove default value for IgnoreCopyProperty for PostOperation serialize --- CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs | 4 ++-- .../JsonConverter/PostOperationJsonConverter.cs | 2 +- CDP4JsonFileDal/JsonFileDal.cs | 4 ++-- CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs | 2 +- CDP4ServicesDal.Tests/PostOperationTestFixture.cs | 2 +- CDP4ServicesDal/CdpServicesDal.cs | 2 +- 6 files changed, 8 insertions(+), 8 deletions(-) diff --git a/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs index cb927415d..7e61c9271 100644 --- a/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs +++ b/CDP4DalJsonSerializer/Cdp4DalJsonSerializer.cs @@ -55,7 +55,7 @@ public class Cdp4DalJsonSerializer : Cdp4JsonSerializer /// The supported version of the data-model /// /// Asserts that the have to be ignored - public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedVersion, bool ignorePostOperationCopyProperty = false) + public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version supportedVersion, bool ignorePostOperationCopyProperty) { this.ignorePostOperationCopyProperty = ignorePostOperationCopyProperty; this.Initialize(metaInfoProvider, supportedVersion); @@ -65,7 +65,7 @@ public Cdp4DalJsonSerializer(IMetaDataProvider metaInfoProvider, Version support /// Initializes a new instance of the class. /// /// Asserts that the have to be ignored - public Cdp4DalJsonSerializer(bool ignorePostOperationCopyProperty = false) + public Cdp4DalJsonSerializer(bool ignorePostOperationCopyProperty) { this.ignorePostOperationCopyProperty = ignorePostOperationCopyProperty; } diff --git a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs index af260a774..37feb0696 100644 --- a/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs +++ b/CDP4DalJsonSerializer/JsonConverter/PostOperationJsonConverter.cs @@ -57,7 +57,7 @@ public class PostOperationJsonConverter: JsonConverter /// Initializes a new instance. /// /// Asserts that the have to be ignored - public PostOperationJsonConverter(bool ignoreCopyProperty = false) + public PostOperationJsonConverter(bool ignoreCopyProperty) { this.ignoreCopyProperty = ignoreCopyProperty; } diff --git a/CDP4JsonFileDal/JsonFileDal.cs b/CDP4JsonFileDal/JsonFileDal.cs index 160486179..932cea6a3 100644 --- a/CDP4JsonFileDal/JsonFileDal.cs +++ b/CDP4JsonFileDal/JsonFileDal.cs @@ -118,7 +118,7 @@ public class JsonFileDal : Dal /// public JsonFileDal() { - this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion, false); } /// @@ -137,7 +137,7 @@ public JsonFileDal(Version dalVersion) this.DalVersion = dalVersion; } - this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Serializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion, false); } /// diff --git a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs index 6d469df8d..f06f92662 100644 --- a/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/PostOperationTestFixture.cs @@ -56,7 +56,7 @@ public class PostOperationTestFixture public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0), false); } [Test] diff --git a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs index 6d469df8d..f06f92662 100644 --- a/CDP4ServicesDal.Tests/PostOperationTestFixture.cs +++ b/CDP4ServicesDal.Tests/PostOperationTestFixture.cs @@ -56,7 +56,7 @@ public class PostOperationTestFixture public void Setup() { var metamodel = new MetaDataProvider(); - this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0)); + this.serializer = new Cdp4DalJsonSerializer(metamodel, new Version(1, 1, 0), false); } [Test] diff --git a/CDP4ServicesDal/CdpServicesDal.cs b/CDP4ServicesDal/CdpServicesDal.cs index 9a2a3cd45..18e02b0ea 100644 --- a/CDP4ServicesDal/CdpServicesDal.cs +++ b/CDP4ServicesDal/CdpServicesDal.cs @@ -100,7 +100,7 @@ public class CdpServicesDal : Dal /// Asserts that the MessagePack deserialization should be used or not. Supported by default public CdpServicesDal(bool isMessagePackSupported = true) { - this.Cdp4JsonSerializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion); + this.Cdp4JsonSerializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion, false); this.MessagePackSerializer = new MessagePackSerializer(); this.isMessagePackSupported = isMessagePackSupported; From 066570305433cc541dc686378c260b97004b8712 Mon Sep 17 00:00:00 2001 From: antoineatrhea Date: Fri, 22 Mar 2024 15:19:35 +0100 Subject: [PATCH 15/17] Missing README in CDP4JsonSerializer --- CDP4JsonSerializer/CDP4JsonSerializer.csproj | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/CDP4JsonSerializer/CDP4JsonSerializer.csproj b/CDP4JsonSerializer/CDP4JsonSerializer.csproj index c989dc7b2..04a57a63f 100644 --- a/CDP4JsonSerializer/CDP4JsonSerializer.csproj +++ b/CDP4JsonSerializer/CDP4JsonSerializer.csproj @@ -37,9 +37,10 @@ $(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb - - - + + + + From 71b11fdf0572530dbdbbd80932f3dca08c1b6ab2 Mon Sep 17 00:00:00 2001 From: Alexander van Delft Date: Mon, 25 Nov 2024 10:00:51 +0100 Subject: [PATCH 16/17] Always support MessagePack deserialization as a DefaultRequestHeader. --- .../CdpServicesDalTestFixture.cs | 4 +-- .../CdpServicesDalTestFixture.cs | 4 +-- CDP4ServicesDal/CdpServicesDal.cs | 28 ++++--------------- 3 files changed, 9 insertions(+), 27 deletions(-) diff --git a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs index 26b2eac6e..767629e19 100644 --- a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs @@ -258,9 +258,9 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() [TestCase(true)] [TestCase(false)] [Category("WebServicesDependent")] - public async Task VerifyThatReadReturnsCorrectDTO(bool isMessagePackSupported) + public async Task VerifyThatReadReturnsCorrectDTO() { - this.dal = new CdpServicesDal(isMessagePackSupported); + this.dal = new CdpServicesDal(); var returned = (await this.dal.Open(this.credentials, this.cancelationTokenSource.Token)).ToList(); Assert.NotNull(returned); diff --git a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs index 1fe4b0b24..7cd34a5c4 100644 --- a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs @@ -235,9 +235,9 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() [TestCase(true)] [TestCase(false)] [Category("WebServicesDependent")] - public async Task VerifyThatReadReturnsCorrectDTO(bool isMessagePackSupported) + public async Task VerifyThatReadReturnsCorrectDTO() { - this.dal = new CdpServicesDal(isMessagePackSupported); + this.dal = new CdpServicesDal(); var returned = (await this.dal.Open(this.credentials, this.cancelationTokenSource.Token)).ToList(); Assert.NotNull(returned); diff --git a/CDP4ServicesDal/CdpServicesDal.cs b/CDP4ServicesDal/CdpServicesDal.cs index 18e02b0ea..b6fe42d0b 100644 --- a/CDP4ServicesDal/CdpServicesDal.cs +++ b/CDP4ServicesDal/CdpServicesDal.cs @@ -89,21 +89,13 @@ public class CdpServicesDal : Dal /// private HttpClient httpClient; - /// - /// Asserts that the MessagePack deserialization should be used or not - /// - private readonly bool isMessagePackSupported; - /// /// Initializes a new instance of the class. /// - /// Asserts that the MessagePack deserialization should be used or not. Supported by default - public CdpServicesDal(bool isMessagePackSupported = true) + public CdpServicesDal() { this.Cdp4JsonSerializer = new Cdp4DalJsonSerializer(this.MetaDataProvider, this.DalVersion, false); this.MessagePackSerializer = new MessagePackSerializer(); - - this.isMessagePackSupported = isMessagePackSupported; } /// @@ -112,15 +104,9 @@ public CdpServicesDal(bool isMessagePackSupported = true) /// /// The (injected) /// - /// Asserts that the MessagePack deserialization should be used or not. Supported by default - public CdpServicesDal(HttpClient httpClient, bool isMessagePackSupported = true) : this(isMessagePackSupported) + public CdpServicesDal(HttpClient httpClient) : this() { - if (httpClient == null) - { - throw new ArgumentNullException(nameof(httpClient)); - } - - this.httpClient = httpClient; + this.httpClient = httpClient ?? throw new ArgumentNullException(nameof(httpClient)); } /// @@ -1061,13 +1047,9 @@ private HttpClient CreateHttpClient(Credentials credentials, HttpClient injected result.BaseAddress = credentials.Uri; result.DefaultRequestHeaders.Accept.Clear(); result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json")); + result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/msgpack")); - if (this.isMessagePackSupported) - { - result.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/msgpack")); - } - - result.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(ASCIIEncoding.ASCII.GetBytes($"{credentials.UserName}:{credentials.Password}"))); + result.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(Encoding.ASCII.GetBytes($"{credentials.UserName}:{credentials.Password}"))); result.DefaultRequestHeaders.Add(Headers.AcceptCdpVersion, Headers.AcceptCdpVersionValue); result.DefaultRequestHeaders.Add("User-Agent", "CDP4 (ECSS-E-TM-10-25 Annex C.2) CDPServicesDal"); From 13ef2e4665e53ea689e5817ab41bc3745a3f35f2 Mon Sep 17 00:00:00 2001 From: Alexander van Delft Date: Tue, 26 Nov 2024 09:22:33 +0100 Subject: [PATCH 17/17] Fix unit tests --- CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs | 3 +-- CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs index 767629e19..bd8c551ff 100644 --- a/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.NetCore.Tests/CdpServicesDalTestFixture.cs @@ -255,8 +255,7 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() Assert.Throws(() => this.dal.Close()); } - [TestCase(true)] - [TestCase(false)] + [Test] [Category("WebServicesDependent")] public async Task VerifyThatReadReturnsCorrectDTO() { diff --git a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs index 7cd34a5c4..8d39de763 100644 --- a/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs +++ b/CDP4ServicesDal.Tests/CdpServicesDalTestFixture.cs @@ -232,8 +232,7 @@ public void VerifyThatDalThatIsNotOpenCannotBeClosed() Assert.Throws(() => this.dal.Close()); } - [TestCase(true)] - [TestCase(false)] + [Test] [Category("WebServicesDependent")] public async Task VerifyThatReadReturnsCorrectDTO() {